From 0a7c76d05918e57df6f4bf3ab6589666dbd7c8a5 Mon Sep 17 00:00:00 2001 From: Eric Arellano <14852634+Eric-Arellano@users.noreply.github.com> Date: Thu, 31 Oct 2024 12:56:36 -0400 Subject: [PATCH] Generate Runtime 0.32 (#2219) --- .../api/qiskit-ibm-runtime/0.31/_package.json | 4 + docs/api/qiskit-ibm-runtime/0.31/_toc.json | 517 +++++++++++++ .../qiskit-ibm-runtime/0.31/debug_tools.mdx | 26 + .../0.31/execution_span.mdx | 29 + .../qiskit-ibm-runtime/0.31/fake_provider.mdx | 150 ++++ docs/api/qiskit-ibm-runtime/0.31/index.mdx | 18 + .../qiskit-ibm-runtime/0.31/noise_learner.mdx | 24 + .../0.31/noise_learner_result.mdx | 21 + docs/api/qiskit-ibm-runtime/0.31/options.mdx | 74 ++ .../0.31/qiskit_ibm_runtime.Batch.mdx | 232 ++++++ .../0.31/qiskit_ibm_runtime.Estimator.mdx | 14 + .../0.31/qiskit_ibm_runtime.EstimatorV2.mdx | 127 ++++ .../0.31/qiskit_ibm_runtime.IBMBackend.mdx | 701 ++++++++++++++++++ ...iskit_ibm_runtime.QiskitRuntimeService.mdx | 391 ++++++++++ .../qiskit_ibm_runtime.RuntimeDecoder.mdx | 52 ++ .../qiskit_ibm_runtime.RuntimeEncoder.mdx | 93 +++ .../0.31/qiskit_ibm_runtime.RuntimeJob.mdx | 539 ++++++++++++++ .../0.31/qiskit_ibm_runtime.RuntimeJobV2.mdx | 455 ++++++++++++ .../0.31/qiskit_ibm_runtime.Sampler.mdx | 14 + .../0.31/qiskit_ibm_runtime.SamplerV2.mdx | 95 +++ .../0.31/qiskit_ibm_runtime.Session.mdx | 214 ++++++ .../qiskit_ibm_runtime.debug_tools.Neat.mdx | 119 +++ ..._ibm_runtime.debug_tools.NeatPubResult.mdx | 42 ++ ...kit_ibm_runtime.debug_tools.NeatResult.mdx | 36 + ...m_runtime.execution_span.ExecutionSpan.mdx | 141 ++++ ..._runtime.execution_span.ExecutionSpans.mdx | 114 +++ ...t_ibm_runtime.execution_span.ShapeType.mdx | 14 + ...t_ibm_runtime.execution_span.SliceSpan.mdx | 128 ++++ ..._ibm_runtime.fake_provider.FakeAlgiers.mdx | 454 ++++++++++++ ...bm_runtime.fake_provider.FakeAlmadenV2.mdx | 464 ++++++++++++ ...ibm_runtime.fake_provider.FakeArmonkV2.mdx | 458 ++++++++++++ ...ibm_runtime.fake_provider.FakeAthensV2.mdx | 454 ++++++++++++ ...ibm_runtime.fake_provider.FakeAuckland.mdx | 454 ++++++++++++ ..._ibm_runtime.fake_provider.FakeBelemV2.mdx | 454 ++++++++++++ ...runtime.fake_provider.FakeBoeblingenV2.mdx | 464 ++++++++++++ ...ibm_runtime.fake_provider.FakeBogotaV2.mdx | 454 ++++++++++++ ...ibm_runtime.fake_provider.FakeBrisbane.mdx | 454 ++++++++++++ ...m_runtime.fake_provider.FakeBrooklynV2.mdx | 454 ++++++++++++ ...runtime.fake_provider.FakeBurlingtonV2.mdx | 460 ++++++++++++ ..._ibm_runtime.fake_provider.FakeCairoV2.mdx | 454 ++++++++++++ ..._runtime.fake_provider.FakeCambridgeV2.mdx | 466 ++++++++++++ ...runtime.fake_provider.FakeCasablancaV2.mdx | 454 ++++++++++++ ...it_ibm_runtime.fake_provider.FakeCusco.mdx | 454 ++++++++++++ ..._ibm_runtime.fake_provider.FakeEssexV2.mdx | 462 ++++++++++++ ...me.fake_provider.FakeFractionalBackend.mdx | 461 ++++++++++++ ...t_ibm_runtime.fake_provider.FakeGeneva.mdx | 454 ++++++++++++ ..._runtime.fake_provider.FakeGuadalupeV2.mdx | 454 ++++++++++++ ..._ibm_runtime.fake_provider.FakeHanoiV2.mdx | 454 ++++++++++++ ...bm_runtime.fake_provider.FakeJakartaV2.mdx | 454 ++++++++++++ ...ntime.fake_provider.FakeJohannesburgV2.mdx | 464 ++++++++++++ ...ibm_runtime.fake_provider.FakeKawasaki.mdx | 454 ++++++++++++ ...bm_runtime.fake_provider.FakeKolkataV2.mdx | 454 ++++++++++++ ...kit_ibm_runtime.fake_provider.FakeKyiv.mdx | 454 ++++++++++++ ...it_ibm_runtime.fake_provider.FakeKyoto.mdx | 454 ++++++++++++ ..._ibm_runtime.fake_provider.FakeLagosV2.mdx | 454 ++++++++++++ ...t_ibm_runtime.fake_provider.FakeLimaV2.mdx | 454 ++++++++++++ ...ibm_runtime.fake_provider.FakeLondonV2.mdx | 462 ++++++++++++ ..._runtime.fake_provider.FakeManhattanV2.mdx | 454 ++++++++++++ ...ibm_runtime.fake_provider.FakeManilaV2.mdx | 454 ++++++++++++ ..._runtime.fake_provider.FakeMelbourneV2.mdx | 454 ++++++++++++ ...m_runtime.fake_provider.FakeMontrealV2.mdx | 454 ++++++++++++ ...ibm_runtime.fake_provider.FakeMumbaiV2.mdx | 454 ++++++++++++ ...bm_runtime.fake_provider.FakeNairobiV2.mdx | 454 ++++++++++++ ...it_ibm_runtime.fake_provider.FakeOsaka.mdx | 454 ++++++++++++ ...kit_ibm_runtime.fake_provider.FakeOslo.mdx | 454 ++++++++++++ ...bm_runtime.fake_provider.FakeOurenseV2.mdx | 460 ++++++++++++ ..._ibm_runtime.fake_provider.FakeParisV2.mdx | 466 ++++++++++++ ...bm_runtime.fake_provider.FakePeekskill.mdx | 454 ++++++++++++ ...it_ibm_runtime.fake_provider.FakePerth.mdx | 454 ++++++++++++ ...ntime.fake_provider.FakePoughkeepsieV2.mdx | 454 ++++++++++++ ...t_ibm_runtime.fake_provider.FakePrague.mdx | 454 ++++++++++++ ...fake_provider.FakeProviderForBackendV2.mdx | 38 + ...t_ibm_runtime.fake_provider.FakeQuebec.mdx | 454 ++++++++++++ ..._ibm_runtime.fake_provider.FakeQuitoV2.mdx | 454 ++++++++++++ ..._runtime.fake_provider.FakeRochesterV2.mdx | 454 ++++++++++++ ...t_ibm_runtime.fake_provider.FakeRomeV2.mdx | 454 ++++++++++++ ...m_runtime.fake_provider.FakeSantiagoV2.mdx | 454 ++++++++++++ ...m_runtime.fake_provider.FakeSherbrooke.mdx | 454 ++++++++++++ ..._runtime.fake_provider.FakeSingaporeV2.mdx | 464 ++++++++++++ ...ibm_runtime.fake_provider.FakeSydneyV2.mdx | 454 ++++++++++++ ...t_ibm_runtime.fake_provider.FakeTorino.mdx | 454 ++++++++++++ ...bm_runtime.fake_provider.FakeTorontoV2.mdx | 454 ++++++++++++ ...m_runtime.fake_provider.FakeValenciaV2.mdx | 454 ++++++++++++ ...t_ibm_runtime.fake_provider.FakeVigoV2.mdx | 460 ++++++++++++ ...runtime.fake_provider.FakeWashingtonV2.mdx | 454 ++++++++++++ ...m_runtime.fake_provider.FakeYorktownV2.mdx | 462 ++++++++++++ ...ibm_runtime.noise_learner.NoiseLearner.mdx | 112 +++ ...ime.options.DynamicalDecouplingOptions.mdx | 64 ++ ...ibm_runtime.options.EnvironmentOptions.mdx | 51 ++ ...t_ibm_runtime.options.EstimatorOptions.mdx | 131 ++++ ...ibm_runtime.options.ExecutionOptionsV2.mdx | 30 + ...time.options.LayerNoiseLearningOptions.mdx | 54 ++ ...me.options.MeasureNoiseLearningOptions.mdx | 38 + ...bm_runtime.options.NoiseLearnerOptions.mdx | 106 +++ .../qiskit_ibm_runtime.options.PecOptions.mdx | 41 + ...bm_runtime.options.ResilienceOptionsV2.mdx | 72 ++ ...time.options.SamplerExecutionOptionsV2.mdx | 46 ++ ...kit_ibm_runtime.options.SamplerOptions.mdx | 72 ++ ...t_ibm_runtime.options.SimulatorOptions.mdx | 70 ++ ...it_ibm_runtime.options.TwirlingOptions.mdx | 81 ++ .../qiskit_ibm_runtime.options.ZneOptions.mdx | 88 +++ ...transpiler.passes.ConvertISAToClifford.mdx | 149 ++++ ...ime.transpiler.passes.ConvertIdToDelay.mdx | 127 ++++ ...passes.scheduling.ALAPScheduleAnalysis.mdx | 142 ++++ ...passes.scheduling.ASAPScheduleAnalysis.mdx | 142 ++++ ...iler.passes.scheduling.BlockBasePadder.mdx | 135 ++++ ...ing.DynamicCircuitInstructionDurations.mdx | 120 +++ ....transpiler.passes.scheduling.PadDelay.mdx | 149 ++++ ...sses.scheduling.PadDynamicalDecoupling.mdx | 286 +++++++ ...m_runtime.transpiler.passes.scheduling.mdx | 372 ++++++++++ ....utils.noise_learner_result.LayerError.mdx | 110 +++ ...oise_learner_result.PauliLindbladError.mdx | 96 +++ ...ime.visualization.draw_layer_error_map.mdx | 39 + .../0.31/runtime_service.mdx | 168 +++++ .../qiskit-ibm-runtime/0.31/transpiler.mdx | 25 + .../qiskit-ibm-runtime/0.31/visualization.mdx | 24 + docs/api/qiskit-ibm-runtime/_package.json | 2 +- docs/api/qiskit-ibm-runtime/_toc.json | 8 + docs/api/qiskit-ibm-runtime/dev/_package.json | 2 +- docs/api/qiskit-ibm-runtime/dev/_toc.json | 8 + .../qiskit-ibm-runtime/dev/execution_span.mdx | 13 +- .../dev/qiskit_ibm_runtime.Estimator.mdx | 2 +- .../dev/qiskit_ibm_runtime.EstimatorV2.mdx | 12 +- .../dev/qiskit_ibm_runtime.IBMBackend.mdx | 44 +- .../dev/qiskit_ibm_runtime.RuntimeDecoder.mdx | 4 +- .../dev/qiskit_ibm_runtime.RuntimeEncoder.mdx | 4 +- .../dev/qiskit_ibm_runtime.RuntimeJob.mdx | 51 +- .../dev/qiskit_ibm_runtime.RuntimeJobV2.mdx | 49 +- .../dev/qiskit_ibm_runtime.SamplerV2.mdx | 10 + ...runtime.execution_span.DoubleSliceSpan.mdx | 128 ++++ ..._runtime.execution_span.ExecutionSpans.mdx | 34 +- ...ibm_runtime.noise_learner.NoiseLearner.mdx | 14 +- ...t_ibm_runtime.options.EstimatorOptions.mdx | 13 +- ...time.options.LayerNoiseLearningOptions.mdx | 14 +- ...bm_runtime.options.NoiseLearnerOptions.mdx | 16 +- .../qiskit_ibm_runtime.options.ZneOptions.mdx | 2 +- ...ime.visualization.draw_execution_spans.mdx | 33 + ...ime.visualization.draw_layer_error_map.mdx | 2 +- .../qiskit-ibm-runtime/dev/visualization.mdx | 1 + .../api/qiskit-ibm-runtime/execution_span.mdx | 13 +- .../qiskit_ibm_runtime.Batch.mdx | 16 +- .../qiskit_ibm_runtime.Estimator.mdx | 2 +- .../qiskit_ibm_runtime.EstimatorV2.mdx | 18 +- .../qiskit_ibm_runtime.IBMBackend.mdx | 44 +- ...iskit_ibm_runtime.QiskitRuntimeService.mdx | 30 +- .../qiskit_ibm_runtime.RuntimeDecoder.mdx | 4 +- .../qiskit_ibm_runtime.RuntimeEncoder.mdx | 4 +- .../qiskit_ibm_runtime.RuntimeJob.mdx | 85 +-- .../qiskit_ibm_runtime.RuntimeJobV2.mdx | 83 +-- .../qiskit_ibm_runtime.Sampler.mdx | 2 +- .../qiskit_ibm_runtime.SamplerV2.mdx | 18 +- .../qiskit_ibm_runtime.Session.mdx | 16 +- .../qiskit_ibm_runtime.debug_tools.Neat.mdx | 10 +- ..._ibm_runtime.debug_tools.NeatPubResult.mdx | 4 +- ...kit_ibm_runtime.debug_tools.NeatResult.mdx | 6 +- ...runtime.execution_span.DoubleSliceSpan.mdx | 128 ++++ ...m_runtime.execution_span.ExecutionSpan.mdx | 8 +- ..._runtime.execution_span.ExecutionSpans.mdx | 34 +- ...t_ibm_runtime.execution_span.SliceSpan.mdx | 8 +- ..._ibm_runtime.fake_provider.FakeAlgiers.mdx | 24 +- ...bm_runtime.fake_provider.FakeAlmadenV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeArmonkV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeAthensV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeAuckland.mdx | 24 +- ..._ibm_runtime.fake_provider.FakeBelemV2.mdx | 24 +- ...runtime.fake_provider.FakeBoeblingenV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeBogotaV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeBrisbane.mdx | 24 +- ...m_runtime.fake_provider.FakeBrooklynV2.mdx | 24 +- ...runtime.fake_provider.FakeBurlingtonV2.mdx | 24 +- ..._ibm_runtime.fake_provider.FakeCairoV2.mdx | 24 +- ..._runtime.fake_provider.FakeCambridgeV2.mdx | 24 +- ...runtime.fake_provider.FakeCasablancaV2.mdx | 24 +- ...it_ibm_runtime.fake_provider.FakeCusco.mdx | 24 +- ..._ibm_runtime.fake_provider.FakeEssexV2.mdx | 24 +- ...me.fake_provider.FakeFractionalBackend.mdx | 24 +- ...t_ibm_runtime.fake_provider.FakeGeneva.mdx | 24 +- ..._runtime.fake_provider.FakeGuadalupeV2.mdx | 24 +- ..._ibm_runtime.fake_provider.FakeHanoiV2.mdx | 24 +- ...bm_runtime.fake_provider.FakeJakartaV2.mdx | 24 +- ...ntime.fake_provider.FakeJohannesburgV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeKawasaki.mdx | 24 +- ...bm_runtime.fake_provider.FakeKolkataV2.mdx | 24 +- ...kit_ibm_runtime.fake_provider.FakeKyiv.mdx | 24 +- ...it_ibm_runtime.fake_provider.FakeKyoto.mdx | 24 +- ..._ibm_runtime.fake_provider.FakeLagosV2.mdx | 24 +- ...t_ibm_runtime.fake_provider.FakeLimaV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeLondonV2.mdx | 24 +- ..._runtime.fake_provider.FakeManhattanV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeManilaV2.mdx | 24 +- ..._runtime.fake_provider.FakeMelbourneV2.mdx | 24 +- ...m_runtime.fake_provider.FakeMontrealV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeMumbaiV2.mdx | 24 +- ...bm_runtime.fake_provider.FakeNairobiV2.mdx | 24 +- ...it_ibm_runtime.fake_provider.FakeOsaka.mdx | 24 +- ...kit_ibm_runtime.fake_provider.FakeOslo.mdx | 24 +- ...bm_runtime.fake_provider.FakeOurenseV2.mdx | 24 +- ..._ibm_runtime.fake_provider.FakeParisV2.mdx | 24 +- ...bm_runtime.fake_provider.FakePeekskill.mdx | 24 +- ...it_ibm_runtime.fake_provider.FakePerth.mdx | 24 +- ...ntime.fake_provider.FakePoughkeepsieV2.mdx | 24 +- ...t_ibm_runtime.fake_provider.FakePrague.mdx | 24 +- ...fake_provider.FakeProviderForBackendV2.mdx | 6 +- ...t_ibm_runtime.fake_provider.FakeQuebec.mdx | 24 +- ..._ibm_runtime.fake_provider.FakeQuitoV2.mdx | 24 +- ..._runtime.fake_provider.FakeRochesterV2.mdx | 24 +- ...t_ibm_runtime.fake_provider.FakeRomeV2.mdx | 24 +- ...m_runtime.fake_provider.FakeSantiagoV2.mdx | 24 +- ...m_runtime.fake_provider.FakeSherbrooke.mdx | 24 +- ..._runtime.fake_provider.FakeSingaporeV2.mdx | 24 +- ...ibm_runtime.fake_provider.FakeSydneyV2.mdx | 24 +- ...t_ibm_runtime.fake_provider.FakeTorino.mdx | 24 +- ...bm_runtime.fake_provider.FakeTorontoV2.mdx | 24 +- ...m_runtime.fake_provider.FakeValenciaV2.mdx | 24 +- ...t_ibm_runtime.fake_provider.FakeVigoV2.mdx | 24 +- ...runtime.fake_provider.FakeWashingtonV2.mdx | 24 +- ...m_runtime.fake_provider.FakeYorktownV2.mdx | 24 +- ...ibm_runtime.noise_learner.NoiseLearner.mdx | 16 +- ...ime.options.DynamicalDecouplingOptions.mdx | 12 +- ...ibm_runtime.options.EnvironmentOptions.mdx | 2 +- ...t_ibm_runtime.options.EstimatorOptions.mdx | 15 +- ...ibm_runtime.options.ExecutionOptionsV2.mdx | 2 +- ...time.options.LayerNoiseLearningOptions.mdx | 14 +- ...me.options.MeasureNoiseLearningOptions.mdx | 2 +- ...bm_runtime.options.NoiseLearnerOptions.mdx | 18 +- .../qiskit_ibm_runtime.options.PecOptions.mdx | 2 +- ...bm_runtime.options.ResilienceOptionsV2.mdx | 2 +- ...time.options.SamplerExecutionOptionsV2.mdx | 2 +- ...kit_ibm_runtime.options.SamplerOptions.mdx | 4 +- ...t_ibm_runtime.options.SimulatorOptions.mdx | 4 +- ...it_ibm_runtime.options.TwirlingOptions.mdx | 2 +- .../qiskit_ibm_runtime.options.ZneOptions.mdx | 4 +- ...transpiler.passes.ConvertISAToClifford.mdx | 4 +- ...ime.transpiler.passes.ConvertIdToDelay.mdx | 4 +- ...passes.scheduling.ALAPScheduleAnalysis.mdx | 4 +- ...passes.scheduling.ASAPScheduleAnalysis.mdx | 4 +- ...iler.passes.scheduling.BlockBasePadder.mdx | 4 +- ...ing.DynamicCircuitInstructionDurations.mdx | 8 +- ....transpiler.passes.scheduling.PadDelay.mdx | 4 +- ...sses.scheduling.PadDynamicalDecoupling.mdx | 4 +- ....utils.noise_learner_result.LayerError.mdx | 30 +- ...oise_learner_result.PauliLindbladError.mdx | 4 +- ...ime.visualization.draw_execution_spans.mdx | 33 + ...ime.visualization.draw_layer_error_map.mdx | 4 +- docs/api/qiskit-ibm-runtime/release-notes.mdx | 392 +++++----- docs/api/qiskit-ibm-runtime/visualization.mdx | 1 + .../api/qiskit-ibm-runtime/0.31/objects.inv | Bin 0 -> 59437 bytes public/api/qiskit-ibm-runtime/dev/objects.inv | Bin 59473 -> 59713 bytes public/api/qiskit-ibm-runtime/objects.inv | Bin 59437 -> 59714 bytes .../0.31/fake_provider-1_00.png | Bin 0 -> 13102 bytes .../0.31/fake_provider-1_01.png | Bin 0 -> 22140 bytes .../0.31/fake_provider-1_02.png | Bin 0 -> 11442 bytes ...ntime.transpiler.passes.scheduling_0_0.png | Bin 0 -> 58146 bytes ...time.transpiler.passes.scheduling_10_0.png | Bin 0 -> 9687 bytes ...time.transpiler.passes.scheduling_11_0.png | Bin 0 -> 7004 bytes ...time.transpiler.passes.scheduling_12_0.png | Bin 0 -> 6991 bytes ...time.transpiler.passes.scheduling_13_0.png | Bin 0 -> 7246 bytes ...time.transpiler.passes.scheduling_14_0.png | Bin 0 -> 18297 bytes ...time.transpiler.passes.scheduling_15_0.png | Bin 0 -> 11921 bytes ...ntime.transpiler.passes.scheduling_1_0.png | Bin 0 -> 62086 bytes ...ntime.transpiler.passes.scheduling_2_0.png | Bin 0 -> 3565 bytes ...ntime.transpiler.passes.scheduling_3_0.png | Bin 0 -> 21200 bytes ...ntime.transpiler.passes.scheduling_4_0.png | Bin 0 -> 21200 bytes ...ntime.transpiler.passes.scheduling_5_0.png | Bin 0 -> 11208 bytes ...ntime.transpiler.passes.scheduling_6_0.png | Bin 0 -> 7598 bytes ...ntime.transpiler.passes.scheduling_7_0.png | Bin 0 -> 8263 bytes ...ntime.transpiler.passes.scheduling_8_0.png | Bin 0 -> 12759 bytes ...ntime.transpiler.passes.scheduling_9_0.png | Bin 0 -> 9282 bytes .../dev/fake_provider-1_02.png | Bin 11498 -> 11721 bytes .../qiskit-ibm-runtime/fake_provider-1_02.png | Bin 11442 -> 12381 bytes scripts/config/api-html-artifacts.json | 3 +- .../config/historical-pages-to-latest.json | 1 + scripts/js/commands/checkInternalLinks.ts | 1 + 273 files changed, 35233 insertions(+), 1303 deletions(-) create mode 100644 docs/api/qiskit-ibm-runtime/0.31/_package.json create mode 100644 docs/api/qiskit-ibm-runtime/0.31/_toc.json create mode 100644 docs/api/qiskit-ibm-runtime/0.31/debug_tools.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/execution_span.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/fake_provider.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/index.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/noise_learner.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/noise_learner_result.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/options.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Batch.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Estimator.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.EstimatorV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.IBMBackend.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.QiskitRuntimeService.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeDecoder.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeEncoder.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJob.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJobV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Sampler.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.SamplerV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Session.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.Neat.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatResult.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ShapeType.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.SliceSpan.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePerth.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePrague.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EnvironmentOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EstimatorOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.PecOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SimulatorOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.TwirlingOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ZneOptions.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/runtime_service.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/transpiler.mdx create mode 100644 docs/api/qiskit-ibm-runtime/0.31/visualization.mdx create mode 100644 docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx create mode 100644 docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx create mode 100644 docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx create mode 100644 docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx create mode 100644 public/api/qiskit-ibm-runtime/0.31/objects.inv create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_00.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_01.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_02.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_0_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_10_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_11_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_12_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_13_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_14_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_15_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_1_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_2_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_3_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_4_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_5_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_6_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_7_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_8_0.png create mode 100644 public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_9_0.png diff --git a/docs/api/qiskit-ibm-runtime/0.31/_package.json b/docs/api/qiskit-ibm-runtime/0.31/_package.json new file mode 100644 index 00000000000..becbcc5520c --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/_package.json @@ -0,0 +1,4 @@ +{ + "name": "qiskit-ibm-runtime", + "version": "0.31.0" +} diff --git a/docs/api/qiskit-ibm-runtime/0.31/_toc.json b/docs/api/qiskit-ibm-runtime/0.31/_toc.json new file mode 100644 index 00000000000..aacef710182 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/_toc.json @@ -0,0 +1,517 @@ +{ + "title": "Qiskit Runtime client", + "children": [ + { + "title": "API index", + "url": "/api/qiskit-ibm-runtime/0.31" + }, + { + "title": "qiskit_ibm_runtime", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/runtime_service" + }, + { + "title": "Batch", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Batch" + }, + { + "title": "Estimator", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Estimator" + }, + { + "title": "EstimatorV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.EstimatorV2" + }, + { + "title": "IBMBackend", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.IBMBackend" + }, + { + "title": "QiskitRuntimeService", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.QiskitRuntimeService" + }, + { + "title": "RuntimeDecoder", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeDecoder" + }, + { + "title": "RuntimeEncoder", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeEncoder" + }, + { + "title": "RuntimeJob", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJob" + }, + { + "title": "RuntimeJobV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJobV2" + }, + { + "title": "Sampler", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Sampler" + }, + { + "title": "SamplerV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.SamplerV2" + }, + { + "title": "Session", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Session" + } + ] + }, + { + "title": "qiskit_ibm_runtime.debug_tools", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/debug_tools" + }, + { + "title": "Neat", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.Neat" + }, + { + "title": "NeatPubResult", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatPubResult" + }, + { + "title": "NeatResult", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatResult" + } + ] + }, + { + "title": "qiskit_ibm_runtime.execution_span", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/execution_span" + }, + { + "title": "ExecutionSpan", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpan" + }, + { + "title": "ExecutionSpans", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpans" + }, + { + "title": "ShapeType", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ShapeType" + }, + { + "title": "SliceSpan", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.SliceSpan" + } + ] + }, + { + "title": "qiskit_ibm_runtime.fake_provider", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/fake_provider" + }, + { + "title": "FakeAlgiers", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlgiers" + }, + { + "title": "FakeAlmadenV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2" + }, + { + "title": "FakeArmonkV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeArmonkV2" + }, + { + "title": "FakeAthensV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAthensV2" + }, + { + "title": "FakeAuckland", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAuckland" + }, + { + "title": "FakeBelemV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBelemV2" + }, + { + "title": "FakeBoeblingenV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2" + }, + { + "title": "FakeBogotaV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBogotaV2" + }, + { + "title": "FakeBrisbane", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrisbane" + }, + { + "title": "FakeBrooklynV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2" + }, + { + "title": "FakeBurlingtonV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2" + }, + { + "title": "FakeCairoV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCairoV2" + }, + { + "title": "FakeCambridgeV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2" + }, + { + "title": "FakeCasablancaV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2" + }, + { + "title": "FakeCusco", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCusco" + }, + { + "title": "FakeEssexV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeEssexV2" + }, + { + "title": "FakeFractionalBackend", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend" + }, + { + "title": "FakeGeneva", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGeneva" + }, + { + "title": "FakeGuadalupeV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2" + }, + { + "title": "FakeHanoiV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeHanoiV2" + }, + { + "title": "FakeJakartaV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJakartaV2" + }, + { + "title": "FakeJohannesburgV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2" + }, + { + "title": "FakeKawasaki", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKawasaki" + }, + { + "title": "FakeKolkataV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKolkataV2" + }, + { + "title": "FakeKyiv", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyiv" + }, + { + "title": "FakeKyoto", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyoto" + }, + { + "title": "FakeLagosV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLagosV2" + }, + { + "title": "FakeLimaV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLimaV2" + }, + { + "title": "FakeLondonV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLondonV2" + }, + { + "title": "FakeManhattanV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManhattanV2" + }, + { + "title": "FakeManilaV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManilaV2" + }, + { + "title": "FakeMelbourneV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2" + }, + { + "title": "FakeMontrealV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMontrealV2" + }, + { + "title": "FakeMumbaiV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2" + }, + { + "title": "FakeNairobiV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeNairobiV2" + }, + { + "title": "FakeOsaka", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOsaka" + }, + { + "title": "FakeOslo", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOslo" + }, + { + "title": "FakeOurenseV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOurenseV2" + }, + { + "title": "FakeParisV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeParisV2" + }, + { + "title": "FakePeekskill", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePeekskill" + }, + { + "title": "FakePerth", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePerth" + }, + { + "title": "FakePoughkeepsieV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2" + }, + { + "title": "FakePrague", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePrague" + }, + { + "title": "FakeProviderForBackendV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2" + }, + { + "title": "FakeQuebec", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuebec" + }, + { + "title": "FakeQuitoV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuitoV2" + }, + { + "title": "FakeRochesterV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRochesterV2" + }, + { + "title": "FakeRomeV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRomeV2" + }, + { + "title": "FakeSantiagoV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2" + }, + { + "title": "FakeSherbrooke", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSherbrooke" + }, + { + "title": "FakeSingaporeV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2" + }, + { + "title": "FakeSydneyV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSydneyV2" + }, + { + "title": "FakeTorino", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorino" + }, + { + "title": "FakeTorontoV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorontoV2" + }, + { + "title": "FakeValenciaV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeValenciaV2" + }, + { + "title": "FakeVigoV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeVigoV2" + }, + { + "title": "FakeWashingtonV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2" + }, + { + "title": "FakeYorktownV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeYorktownV2" + } + ] + }, + { + "title": "qiskit_ibm_runtime.noise_learner", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/noise_learner" + }, + { + "title": "NoiseLearner", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.noise_learner.NoiseLearner" + } + ] + }, + { + "title": "qiskit_ibm_runtime.options", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/options" + }, + { + "title": "DynamicalDecouplingOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.DynamicalDecouplingOptions" + }, + { + "title": "EnvironmentOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EnvironmentOptions" + }, + { + "title": "EstimatorOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EstimatorOptions" + }, + { + "title": "ExecutionOptionsV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ExecutionOptionsV2" + }, + { + "title": "LayerNoiseLearningOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.LayerNoiseLearningOptions" + }, + { + "title": "MeasureNoiseLearningOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions" + }, + { + "title": "NoiseLearnerOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.NoiseLearnerOptions" + }, + { + "title": "PecOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.PecOptions" + }, + { + "title": "ResilienceOptionsV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ResilienceOptionsV2" + }, + { + "title": "SamplerExecutionOptionsV2", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2" + }, + { + "title": "SamplerOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerOptions" + }, + { + "title": "SimulatorOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SimulatorOptions" + }, + { + "title": "TwirlingOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.TwirlingOptions" + }, + { + "title": "ZneOptions", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ZneOptions" + } + ] + }, + { + "title": "qiskit_ibm_runtime.transpiler.passes", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/transpiler" + }, + { + "title": "ConvertIdToDelay", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay" + }, + { + "title": "ConvertISAToClifford", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford" + } + ] + }, + { + "title": "qiskit_ibm_runtime.transpiler.passes.scheduling", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling" + }, + { + "title": "ALAPScheduleAnalysis", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis" + }, + { + "title": "ASAPScheduleAnalysis", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis" + }, + { + "title": "BlockBasePadder", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder" + }, + { + "title": "DynamicCircuitInstructionDurations", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations" + }, + { + "title": "PadDelay", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay" + }, + { + "title": "PadDynamicalDecoupling", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling" + } + ] + }, + { + "title": "qiskit_ibm_runtime.utils.noise_learner_result", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/noise_learner_result" + }, + { + "title": "LayerError", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.LayerError" + }, + { + "title": "PauliLindbladError", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError" + } + ] + }, + { + "title": "qiskit_ibm_runtime.visualization", + "children": [ + { + "title": "Module overview", + "url": "/api/qiskit-ibm-runtime/0.31/visualization" + }, + { + "title": "draw_layer_error_map", + "url": "/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.visualization.draw_layer_error_map" + } + ] + }, + { + "title": "Release notes", + "url": "/api/qiskit-ibm-runtime/release-notes" + } + ], + "collapsed": true +} + diff --git a/docs/api/qiskit-ibm-runtime/0.31/debug_tools.mdx b/docs/api/qiskit-ibm-runtime/0.31/debug_tools.mdx new file mode 100644 index 00000000000..9bfae74d34d --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/debug_tools.mdx @@ -0,0 +1,26 @@ +--- +title: debug_tools +description: API reference for qiskit_ibm_runtime.debug_tools +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.debug_tools +--- + + + + + +# Debugging tools + +`qiskit_ibm_runtime.debug_tools` + +The tools for debugging and analyzing qiskit-ibm-runtime jobs. + +## Classes + +| | | +| -------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------ | +| [`Neat`](qiskit_ibm_runtime.debug_tools.Neat "qiskit_ibm_runtime.debug_tools.Neat")(backend\[, noise\_model]) | A class to help understand the expected performance of estimator jobs. | +| [`NeatResult`](qiskit_ibm_runtime.debug_tools.NeatResult "qiskit_ibm_runtime.debug_tools.NeatResult")(pub\_results) | A container for multiple [`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.NeatPubResult") objects. | +| [`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.NeatPubResult")(vals) | A class to store the PUB results of `Neat`. | + diff --git a/docs/api/qiskit-ibm-runtime/0.31/execution_span.mdx b/docs/api/qiskit-ibm-runtime/0.31/execution_span.mdx new file mode 100644 index 00000000000..9d0cf9f8970 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/execution_span.mdx @@ -0,0 +1,29 @@ +--- +title: execution_span +description: API reference for qiskit_ibm_runtime.execution_span +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.execution_span +--- + + + + + +# Execution Spans + +`qiskit_ibm_runtime.execution_span` + +## Overview + +An [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans") class instance is an iterable of [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")s, where each iterand gives timing information about a chunk of data. Execution spans are returned as part of the metadata of a primitive job result. + +## Classes + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")(start, stop) | Abstract parent for classes that store an execution time span for a subset of job data. | +| [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans")(spans) | A collection of timings for pub results. | +| [`ShapeType`](qiskit_ibm_runtime.execution_span.ShapeType "qiskit_ibm_runtime.execution_span.ShapeType") | alias of `Tuple`\[`int`, ...] | +| [`SliceSpan`](qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan")(start, stop, data\_slices) | An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. | + diff --git a/docs/api/qiskit-ibm-runtime/0.31/fake_provider.mdx b/docs/api/qiskit-ibm-runtime/0.31/fake_provider.mdx new file mode 100644 index 00000000000..a2555db839c --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/fake_provider.mdx @@ -0,0 +1,150 @@ +--- +title: fake_provider +description: API reference for qiskit_ibm_runtime.fake_provider +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.fake_provider +--- + + + + + +# Fake Provider + +`qiskit_ibm_runtime.fake_provider` + +## Overview + +The fake provider module contains fake providers and fake backends classes. The fake backends are built to mimic the behaviors of IBM Quantum systems using system snapshots. The system snapshots contain important information about the quantum system such as coupling map, basis gates, qubit properties (T1, T2, error rate, etc.) which are useful for testing the transpiler and performing noisy simulations of the system. + +## Example Usage + +Here is an example of using a fake backend for transpilation and simulation. + +```python +from qiskit import QuantumCircuit +from qiskit import transpile +from qiskit.visualization import plot_histogram +from qiskit_ibm_runtime import SamplerV2 +from qiskit_ibm_runtime.fake_provider import FakeManilaV2 + +# Get a fake backend from the fake provider +backend = FakeManilaV2() + +# Create a simple circuit +circuit = QuantumCircuit(3) +circuit.h(0) +circuit.cx(0,1) +circuit.cx(0,2) +circuit.measure_all() +circuit.draw('mpl', style="iqp") + +# Transpile the ideal circuit to a circuit that can be directly executed by the backend +transpiled_circuit = transpile(circuit, backend) +transpiled_circuit.draw('mpl', style="iqp") + +# Run the transpiled circuit using the simulated fake backend +sampler = SamplerV2(backend) +job = sampler.run([transpiled_circuit]) +pub_result = job.result()[0] +counts = pub_result.data.meas.get_counts() +plot_histogram(counts) +``` + +![../\_images/fake\_provider-1\_00.png](/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_00.png) + +![../\_images/fake\_provider-1\_01.png](/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_01.png) + +![../\_images/fake\_provider-1\_02.png](/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_02.png) + + + Please note that the simulation is done using a noise model generated from system snapshots obtained in the past (sometimes a few years ago) and the results are not representative of the latest behaviours of the real quantum system which the fake backend is mimicking. If you want to run noisy simulations to compare with the real quantum system, you should use the `qiskit_aer` library. After installation, you can follow the steps below to generate a simulator that mimics a real quantum system with the latest calibration results. + + ```python + from qiskit_ibm_runtime import QiskitRuntimeService + from qiskit_aer import AerSimulator + + # get a real backend from the runtime service + service = QiskitRuntimeService() + backend = service.backend('ibmq_manila') + + # generate a simulator that mimics the real quantum system with the latest calibration results + backend_sim = AerSimulator.from_backend(backend) + ``` + + +## Fake Providers + +Fake providers provide access to a list of fake backends. + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------ | +| [`FakeProviderForBackendV2`](qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2 "qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2")() | Fake provider containing fake V2 backends. | + +## Fake Backends + +### Fake V2 Backends + +Fake V2 backends are fake backends with IBM Quantum systems snapshots implemented with `BackendV2` interface. They are all subclasses of `FakeBackendV2`. + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- | +| [`FakeAlgiers`](qiskit_ibm_runtime.fake_provider.FakeAlgiers "qiskit_ibm_runtime.fake_provider.FakeAlgiers")() | A fake 27 qubit backend. | +| [`FakeAlmadenV2`](qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 "qiskit_ibm_runtime.fake_provider.FakeAlmadenV2")() | A fake Almaden V2 backend. | +| [`FakeArmonkV2`](qiskit_ibm_runtime.fake_provider.FakeArmonkV2 "qiskit_ibm_runtime.fake_provider.FakeArmonkV2")() | A fake 1 qubit backend. | +| [`FakeAthensV2`](qiskit_ibm_runtime.fake_provider.FakeAthensV2 "qiskit_ibm_runtime.fake_provider.FakeAthensV2")() | A fake 5 qubit backend. | +| [`FakeAuckland`](qiskit_ibm_runtime.fake_provider.FakeAuckland "qiskit_ibm_runtime.fake_provider.FakeAuckland")() | A fake 27 qubit backend. | +| [`FakeBelemV2`](qiskit_ibm_runtime.fake_provider.FakeBelemV2 "qiskit_ibm_runtime.fake_provider.FakeBelemV2")() | A fake 5 qubit backend. | +| [`FakeBoeblingenV2`](qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 "qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2")() | A fake Boeblingen V2 backend. | +| [`FakeBogotaV2`](qiskit_ibm_runtime.fake_provider.FakeBogotaV2 "qiskit_ibm_runtime.fake_provider.FakeBogotaV2")() | A fake 5 qubit backend. | +| [`FakeBrisbane`](qiskit_ibm_runtime.fake_provider.FakeBrisbane "qiskit_ibm_runtime.fake_provider.FakeBrisbane")() | A fake 127 qubit backend. | +| [`FakeBrooklynV2`](qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 "qiskit_ibm_runtime.fake_provider.FakeBrooklynV2")() | A fake Brooklyn V2 backend. | +| [`FakeBurlingtonV2`](qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 "qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2")() | A fake 5 qubit backend. | +| [`FakeCairoV2`](qiskit_ibm_runtime.fake_provider.FakeCairoV2 "qiskit_ibm_runtime.fake_provider.FakeCairoV2")() | A fake 27 qubit backend. | +| [`FakeCambridgeV2`](qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 "qiskit_ibm_runtime.fake_provider.FakeCambridgeV2")() | A fake Cambridge backend. | +| [`FakeCasablancaV2`](qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 "qiskit_ibm_runtime.fake_provider.FakeCasablancaV2")() | A fake 7 qubit backend. | +| [`FakeCusco`](qiskit_ibm_runtime.fake_provider.FakeCusco "qiskit_ibm_runtime.fake_provider.FakeCusco")() | A fake 127 qubit backend. | +| [`FakeEssexV2`](qiskit_ibm_runtime.fake_provider.FakeEssexV2 "qiskit_ibm_runtime.fake_provider.FakeEssexV2")() | A fake 5 qubit backend. | +| [`FakeGeneva`](qiskit_ibm_runtime.fake_provider.FakeGeneva "qiskit_ibm_runtime.fake_provider.FakeGeneva")() | A fake 27 qubit backend. | +| [`FakeGuadalupeV2`](qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 "qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2")() | A fake 16 qubit backend. | +| [`FakeHanoiV2`](qiskit_ibm_runtime.fake_provider.FakeHanoiV2 "qiskit_ibm_runtime.fake_provider.FakeHanoiV2")() | A fake 27 qubit backend. | +| [`FakeJakartaV2`](qiskit_ibm_runtime.fake_provider.FakeJakartaV2 "qiskit_ibm_runtime.fake_provider.FakeJakartaV2")() | A fake 7 qubit V2 backend. | +| [`FakeJohannesburgV2`](qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 "qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2")() | A fake Johannesburg V2 backend. | +| [`FakeKawasaki`](qiskit_ibm_runtime.fake_provider.FakeKawasaki "qiskit_ibm_runtime.fake_provider.FakeKawasaki")() | A fake 127 qubit backend. | +| [`FakeKolkataV2`](qiskit_ibm_runtime.fake_provider.FakeKolkataV2 "qiskit_ibm_runtime.fake_provider.FakeKolkataV2")() | A fake 27 qubit backend. | +| [`FakeKyiv`](qiskit_ibm_runtime.fake_provider.FakeKyiv "qiskit_ibm_runtime.fake_provider.FakeKyiv")() | A fake 127 qubit backend. | +| [`FakeKyoto`](qiskit_ibm_runtime.fake_provider.FakeKyoto "qiskit_ibm_runtime.fake_provider.FakeKyoto")() | A fake 127 qubit backend. | +| [`FakeLagosV2`](qiskit_ibm_runtime.fake_provider.FakeLagosV2 "qiskit_ibm_runtime.fake_provider.FakeLagosV2")() | A fake 7 qubit backend. | +| [`FakeLimaV2`](qiskit_ibm_runtime.fake_provider.FakeLimaV2 "qiskit_ibm_runtime.fake_provider.FakeLimaV2")() | A fake 5 qubit backend. | +| [`FakeFractionalBackend`](qiskit_ibm_runtime.fake_provider.FakeFractionalBackend "qiskit_ibm_runtime.fake_provider.FakeFractionalBackend")() | A fake 5 qubit backend with dynamic and fractional feature modeled based on FakeLima. | +| [`FakeLondonV2`](qiskit_ibm_runtime.fake_provider.FakeLondonV2 "qiskit_ibm_runtime.fake_provider.FakeLondonV2")() | A fake 5 qubit backend. | +| [`FakeManhattanV2`](qiskit_ibm_runtime.fake_provider.FakeManhattanV2 "qiskit_ibm_runtime.fake_provider.FakeManhattanV2")() | A fake Manhattan backend. | +| [`FakeManilaV2`](qiskit_ibm_runtime.fake_provider.FakeManilaV2 "qiskit_ibm_runtime.fake_provider.FakeManilaV2")() | A fake 5 qubit backend. | +| [`FakeMelbourneV2`](qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 "qiskit_ibm_runtime.fake_provider.FakeMelbourneV2")() | A fake 14 qubit backend. | +| [`FakeMontrealV2`](qiskit_ibm_runtime.fake_provider.FakeMontrealV2 "qiskit_ibm_runtime.fake_provider.FakeMontrealV2")() | A fake 27 qubit backend. | +| [`FakeMumbaiV2`](qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 "qiskit_ibm_runtime.fake_provider.FakeMumbaiV2")() | A fake 27 qubit backend. | +| [`FakeNairobiV2`](qiskit_ibm_runtime.fake_provider.FakeNairobiV2 "qiskit_ibm_runtime.fake_provider.FakeNairobiV2")() | A fake 7 qubit backend. | +| [`FakeOsaka`](qiskit_ibm_runtime.fake_provider.FakeOsaka "qiskit_ibm_runtime.fake_provider.FakeOsaka")() | A fake 127 qubit backend. | +| [`FakeOslo`](qiskit_ibm_runtime.fake_provider.FakeOslo "qiskit_ibm_runtime.fake_provider.FakeOslo")() | A fake 7 qubit backend. | +| [`FakeOurenseV2`](qiskit_ibm_runtime.fake_provider.FakeOurenseV2 "qiskit_ibm_runtime.fake_provider.FakeOurenseV2")() | A fake 5 qubit backend. | +| [`FakeParisV2`](qiskit_ibm_runtime.fake_provider.FakeParisV2 "qiskit_ibm_runtime.fake_provider.FakeParisV2")() | A fake Paris backend. | +| [`FakePeekskill`](qiskit_ibm_runtime.fake_provider.FakePeekskill "qiskit_ibm_runtime.fake_provider.FakePeekskill")() | A fake 27 qubit backend. | +| [`FakePerth`](qiskit_ibm_runtime.fake_provider.FakePerth "qiskit_ibm_runtime.fake_provider.FakePerth")() | A fake 7 qubit backend. | +| [`FakePrague`](qiskit_ibm_runtime.fake_provider.FakePrague "qiskit_ibm_runtime.fake_provider.FakePrague")() | A fake 33 qubit backend. | +| [`FakePoughkeepsieV2`](qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 "qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2")() | A fake Poughkeepsie backend. | +| [`FakeQuebec`](qiskit_ibm_runtime.fake_provider.FakeQuebec "qiskit_ibm_runtime.fake_provider.FakeQuebec")() | A fake 127 qubit backend. | +| [`FakeQuitoV2`](qiskit_ibm_runtime.fake_provider.FakeQuitoV2 "qiskit_ibm_runtime.fake_provider.FakeQuitoV2")() | A fake 5 qubit backend. | +| [`FakeRochesterV2`](qiskit_ibm_runtime.fake_provider.FakeRochesterV2 "qiskit_ibm_runtime.fake_provider.FakeRochesterV2")() | A fake Rochester backend. | +| [`FakeRomeV2`](qiskit_ibm_runtime.fake_provider.FakeRomeV2 "qiskit_ibm_runtime.fake_provider.FakeRomeV2")() | A fake 5 qubit backend. | +| [`FakeSantiagoV2`](qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 "qiskit_ibm_runtime.fake_provider.FakeSantiagoV2")() | A fake Santiago backend. | +| [`FakeSherbrooke`](qiskit_ibm_runtime.fake_provider.FakeSherbrooke "qiskit_ibm_runtime.fake_provider.FakeSherbrooke")() | A fake 127 qubit backend. | +| [`FakeSingaporeV2`](qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 "qiskit_ibm_runtime.fake_provider.FakeSingaporeV2")() | A fake Singapore backend. | +| [`FakeSydneyV2`](qiskit_ibm_runtime.fake_provider.FakeSydneyV2 "qiskit_ibm_runtime.fake_provider.FakeSydneyV2")() | A fake 27 qubit backend. | +| [`FakeTorino`](qiskit_ibm_runtime.fake_provider.FakeTorino "qiskit_ibm_runtime.fake_provider.FakeTorino")() | A fake 133 qubit backend. | +| [`FakeTorontoV2`](qiskit_ibm_runtime.fake_provider.FakeTorontoV2 "qiskit_ibm_runtime.fake_provider.FakeTorontoV2")() | A fake 27 qubit backend. | +| [`FakeValenciaV2`](qiskit_ibm_runtime.fake_provider.FakeValenciaV2 "qiskit_ibm_runtime.fake_provider.FakeValenciaV2")() | A fake 5 qubit backend. | +| [`FakeVigoV2`](qiskit_ibm_runtime.fake_provider.FakeVigoV2 "qiskit_ibm_runtime.fake_provider.FakeVigoV2")() | A fake 5 qubit backend. | +| [`FakeWashingtonV2`](qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 "qiskit_ibm_runtime.fake_provider.FakeWashingtonV2")() | A fake 127 qubit backend. | +| [`FakeYorktownV2`](qiskit_ibm_runtime.fake_provider.FakeYorktownV2 "qiskit_ibm_runtime.fake_provider.FakeYorktownV2")() | A fake 5 qubit backend. | + diff --git a/docs/api/qiskit-ibm-runtime/0.31/index.mdx b/docs/api/qiskit-ibm-runtime/0.31/index.mdx new file mode 100644 index 00000000000..1a96e625b79 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/index.mdx @@ -0,0 +1,18 @@ +--- +title: Qiskit Runtime Client API Docs +description: API documentation for the qiskit-ibm-runtime client +--- + +# qiskit-ibm-runtime API reference + +* [Qiskit Runtime (`qiskit_ibm_runtime`)](runtime_service) +* [Noise learner (`qiskit_ibm_runtime.noise_learner.NoiseLearner`)](noise_learner) +* [NoiseLearner result classes (`qiskit_ibm_runtime.utils.noise_learner_result`)](noise_learner_result) +* [Primitive options (`qiskit_ibm_runtime.options`)](options) +* [Transpiler passes (`qiskit_ibm_runtime.transpiler.passes`)](transpiler) +* [Transpiler scheduling passes (`qiskit_ibm_runtime.transpiler.passes.scheduling`)](qiskit_ibm_runtime.transpiler.passes.scheduling) +* [Fake Provider (`qiskit_ibm_runtime.fake_provider`)](fake_provider) +* [Execution Spans (`qiskit_ibm_runtime.execution_span`)](execution_span) +* [Debugging tools (`qiskit_ibm_runtime.debug_tools`)](debug_tools) +* [Visualization (`qiskit_ibm_runtime.visualization`)](visualization) + diff --git a/docs/api/qiskit-ibm-runtime/0.31/noise_learner.mdx b/docs/api/qiskit-ibm-runtime/0.31/noise_learner.mdx new file mode 100644 index 00000000000..fd91bfc9cd4 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/noise_learner.mdx @@ -0,0 +1,24 @@ +--- +title: noise_learner +description: API reference for qiskit_ibm_runtime.noise_learner +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.noise_learner +--- + + + + + +# Noise learner + +`qiskit_ibm_runtime.noise_learner.NoiseLearner` + +The tools to characterize the noise processes affecting the gates in noisy quantum circuits. + +## Classes + +| | | +| --------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------- | +| [`NoiseLearner`](qiskit_ibm_runtime.noise_learner.NoiseLearner "qiskit_ibm_runtime.noise_learner.NoiseLearner")(\[mode, options]) | Class for executing noise learning experiments. | + diff --git a/docs/api/qiskit-ibm-runtime/0.31/noise_learner_result.mdx b/docs/api/qiskit-ibm-runtime/0.31/noise_learner_result.mdx new file mode 100644 index 00000000000..277fbade34b --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/noise_learner_result.mdx @@ -0,0 +1,21 @@ +--- +title: noise_learner_result +description: API reference for qiskit_ibm_runtime.utils.noise_learner_result +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.utils.noise_learner_result +--- + + + + + +# NoiseLearner result classes + +`qiskit_ibm_runtime.utils.noise_learner_result` + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------- | +| [`PauliLindbladError`](qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError")(generators, rates) | A Pauli error channel generated by a Pauli Lindblad dissipators. | +| [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError")(circuit, qubits\[, error]) | The error channel (in Pauli-Lindblad format) of a single layer of instructions. | + diff --git a/docs/api/qiskit-ibm-runtime/0.31/options.mdx b/docs/api/qiskit-ibm-runtime/0.31/options.mdx new file mode 100644 index 00000000000..bc56ae4cf27 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/options.mdx @@ -0,0 +1,74 @@ +--- +title: options +description: API reference for qiskit_ibm_runtime.options +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.options +--- + + + + + +# Primitive options + +`qiskit_ibm_runtime.options` + +Options that can be passed to the Qiskit Runtime primitives. + +## V2 Primitives + +`SamplerV2` and `EstimatorV2` each have their own options. You can use the `options` attribute to set the options. For example: + +```python +from qiskit_ibm_runtime import QiskitRuntimeService, EstimatorV2 + +service = QiskitRuntimeService() +backend = service.least_busy(operational=True, simulator=False) +estimator = EstimatorV2(mode=backend) +estimator.options.resilience_level = 1 +``` + +You can also use the `update()` method to do bulk update. For example: + +```python +from qiskit_ibm_runtime import QiskitRuntimeService, EstimatorV2 + +service = QiskitRuntimeService() +backend = service.least_busy(operational=True, simulator=False) +estimator = EstimatorV2(mode=backend) +estimator.options.update(resilience_level=1) +``` + +Refer to [`SamplerOptions`](qiskit_ibm_runtime.options.SamplerOptions "qiskit_ibm_runtime.options.SamplerOptions") and [`EstimatorOptions`](qiskit_ibm_runtime.options.EstimatorOptions "qiskit_ibm_runtime.options.EstimatorOptions") for V2 Sampler and V2 Estimator options, respectively. + + + If an option is not specified, the server default value is used. The default values are subject to change. Refer to this current module’s documentation for the latest defaults. + + +## Classes + +### Base primitive options + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------- | ------------------------- | +| [`EstimatorOptions`](qiskit_ibm_runtime.options.EstimatorOptions "qiskit_ibm_runtime.options.EstimatorOptions")(\*args, \*\*kwargs) | Options for V2 Estimator. | +| [`SamplerOptions`](qiskit_ibm_runtime.options.SamplerOptions "qiskit_ibm_runtime.options.SamplerOptions")(\*args, \*\*kwargs) | Options for V2 Sampler. | + +### Suboptions + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`NoiseLearnerOptions`](qiskit_ibm_runtime.options.NoiseLearnerOptions "qiskit_ibm_runtime.options.NoiseLearnerOptions")(\*args, \*\*kwargs) | Options for [`NoiseLearner`](qiskit_ibm_runtime.noise_learner.NoiseLearner "qiskit_ibm_runtime.noise_learner.NoiseLearner"). | +| [`DynamicalDecouplingOptions`](qiskit_ibm_runtime.options.DynamicalDecouplingOptions "qiskit_ibm_runtime.options.DynamicalDecouplingOptions")(\*args, \*\*kwargs) | Options for dynamical decoupling (DD). | +| [`ResilienceOptionsV2`](qiskit_ibm_runtime.options.ResilienceOptionsV2 "qiskit_ibm_runtime.options.ResilienceOptionsV2")(\*args, \*\*kwargs) | Resilience options for V2 Estimator. | +| [`LayerNoiseLearningOptions`](qiskit_ibm_runtime.options.LayerNoiseLearningOptions "qiskit_ibm_runtime.options.LayerNoiseLearningOptions")(\*args, \*\*kwargs) | Options for learning layer noise. | +| [`MeasureNoiseLearningOptions`](qiskit_ibm_runtime.options.MeasureNoiseLearningOptions "qiskit_ibm_runtime.options.MeasureNoiseLearningOptions")(\*args, \*\*kwargs) | Options for measurement noise learning. | +| [`PecOptions`](qiskit_ibm_runtime.options.PecOptions "qiskit_ibm_runtime.options.PecOptions")(\*args, \*\*kwargs) | Probabalistic error cancellation mitigation options. | +| [`ZneOptions`](qiskit_ibm_runtime.options.ZneOptions "qiskit_ibm_runtime.options.ZneOptions")(\*args, \*\*kwargs) | Zero noise extrapolation mitigation options. | +| [`TwirlingOptions`](qiskit_ibm_runtime.options.TwirlingOptions "qiskit_ibm_runtime.options.TwirlingOptions")(\*args, \*\*kwargs) | Twirling options. | +| [`ExecutionOptionsV2`](qiskit_ibm_runtime.options.ExecutionOptionsV2 "qiskit_ibm_runtime.options.ExecutionOptionsV2")(\*args, \*\*kwargs) | Execution options for V2 primitives. | +| [`SamplerExecutionOptionsV2`](qiskit_ibm_runtime.options.SamplerExecutionOptionsV2 "qiskit_ibm_runtime.options.SamplerExecutionOptionsV2")(\*args, \*\*kwargs) | Extension of [`ExecutionOptionsV2`](qiskit_ibm_runtime.options.ExecutionOptionsV2 "qiskit_ibm_runtime.options.ExecutionOptionsV2") for the sampler primitive. | +| [`EnvironmentOptions`](qiskit_ibm_runtime.options.EnvironmentOptions "qiskit_ibm_runtime.options.EnvironmentOptions")(\*args, \*\*kwargs) | Options related to the execution environment. | +| [`SimulatorOptions`](qiskit_ibm_runtime.options.SimulatorOptions "qiskit_ibm_runtime.options.SimulatorOptions")(\*args, \*\*kwargs) | Simulator options. | + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Batch.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Batch.mdx new file mode 100644 index 00000000000..99cc487da48 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Batch.mdx @@ -0,0 +1,232 @@ +--- +title: Batch +description: API reference for qiskit_ibm_runtime.Batch +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.Batch +--- + +# Batch + + + Class for running jobs in batch execution mode. + + The `batch` mode is designed to efficiently perform experiments that comprise multiple independent jobs. + + **Using the `batch` mode provides the following benefits:** + + * The jobs’ classical computation, such as compilation, is run in parallel. Thus, running multiple jobs in a batch is significantly faster than running them serially. + * There is usually minimal delay between job, which can help avoid drift. + * If you partition your workload into multiple jobs and run them in `batch` mode, you can get results from individual jobs, which makes them more flexible to work with. For example, if a job’s results do not meet your expectations, you can cancel the remaining jobs, or simply re-submit that individual job and avoid re-running the entire workload. + + Batch mode can shorten processing time if all jobs are provided at the outset. If you want to submit iterative jobs, use `session` mode instead. + + You can open a Qiskit Runtime batch by using this `Batch` class, then submit jobs to one or more primitives. + + For example: + + ```python + import numpy as np + from qiskit.circuit.library import IQP + from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + from qiskit.quantum_info import random_hermitian + from qiskit_ibm_runtime import QiskitRuntimeService, SamplerV2 as Sampler, Batch + + n_qubits = 127 + + service = QiskitRuntimeService() + backend = service.least_busy(operational=True, simulator=False, min_num_qubits=n_qubits) + + rng = np.random.default_rng() + mats = [np.real(random_hermitian(n_qubits, seed=rng)) for _ in range(30)] + circuits = [IQP(mat) for mat in mats] + for circuit in circuits: + circuit.measure_all() + + pm = generate_preset_pass_manager(backend=backend, optimization_level=1) + isa_circuits = pm.run(circuits) + + max_circuits = 10 + all_partitioned_circuits = [] + for i in range(0, len(isa_circuits), max_circuits): + all_partitioned_circuits.append(isa_circuits[i : i + max_circuits]) + jobs = [] + start_idx = 0 + + with Batch(backend=backend): + sampler = Sampler() + for partitioned_circuits in all_partitioned_circuits: + job = sampler.run(partitioned_circuits) + jobs.append(job) + ``` + + For more details, check the “[Run jobs in a batch](/guides/run-jobs-batch)” page. + + Batch constructor. + + **Parameters** + + * **service** (`Optional`\[[`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")]) – (DEPRECATED) Optional instance of the `QiskitRuntimeService` class. If `None`, the service associated with the backend, if known, is used. Otherwise `QiskitRuntimeService()` is used to initialize your default saved account. + * **backend** (`Union`\[`str`, [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "(in Qiskit v1.2)"), [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)"), `None`]) – Instance of `Backend` class or backend string name. Note that passing a backend name is deprecated. + * **max\_time** (`Union`\[`int`, `str`, `None`]) – Maximum amount of time a runtime session can be open before being forcibly closed. Can be specified as seconds (int) or a string like “2h 30m 40s”. This value must be less than the [system imposed maximum](/guides/max-execution-time). + + **Raises** + + **ValueError** – If an input value is invalid. + + ## Attributes + + ### service + + + Return service associated with this session. + + **Return type** + + [`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService") + + **Returns** + + [`qiskit_ibm_runtime.QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.QiskitRuntimeService") associated with this session. + + + ### session\_id + + + Return the session ID. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Session ID. None if the backend is a simulator. + + + ## Methods + + ### backend + + + Return backend for this session. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Backend for this session. None if unknown. + + + ### cancel + + + Cancel all pending jobs in a session. + + **Return type** + + `None` + + + ### close + + + Close the session so new jobs will no longer be accepted, but existing queued or running jobs will run to completion. The session will be terminated once there are no more pending jobs. + + **Return type** + + `None` + + + ### details + + + Return session details. + + **Return type** + + `Optional`\[`Dict`\[`str`, `Any`]] + + **Returns** + + A dictionary with the sessions details. + + * `id`: id of the session. + * `backend_name`: backend used for the session. + * `interactive_timeout`: The maximum idle time (in seconds) between jobs that is allowed to occur before the session is deactivated. + * `max_time`: Maximum allowed time (in seconds) for the session, subject to plan limits. + * `active_timeout`: The maximum time (in seconds) a session can stay active. + * `state`: State of the session - open, active, inactive, or closed. + * `accepting_jobs`: Whether or not the session is accepting jobs. + * `last_job_started`: Timestamp of when the last job in the session started. + * `last_job_completed`: Timestamp of when the last job in the session completed. + * `started_at`: Timestamp of when the session was started. + * `closed_at`: Timestamp of when the session was closed. + * `activated_at`: Timestamp of when the session state was changed to active. + * `mode`: Execution mode of the session. + * `usage_time`: The usage time, in seconds, of this Session or Batch. Usage is defined as the time a quantum system is committed to complete a job. + + + ### from\_id + + + Construct a Session object with a given session\_id + + **Parameters** + + * **session\_id** (`str`) – the id of the session to be created. This must be an already existing session id. + + * **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – + + instance of the `QiskitRuntimeService` class. + + **Raises:** + + IBMInputValueError: If given session\_id does not exist. + + **Return type** + + [`Session`](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.session.Session") + + **Returns** + + A new Session with the given `session_id` + + + ### status + + + Return current session status. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Session status as a string. + + * `Pending`: Session is created but not active. It will become active when the next job of this session is dequeued. + * `In progress, accepting new jobs`: session is active and accepting new jobs. + * `In progress, not accepting new jobs`: session is active and not accepting new jobs. + * `Closed`: max\_time expired or session was explicitly closed. + * `None`: status details are not available. + + + ### usage + + + Return session usage in seconds. + + Session usage is the time from when the first job starts until the session goes inactive, is closed, or when its last job completes, whichever happens last. + + Batch usage is the amount of time all jobs spend on the QPU. + + **Return type** + + `Optional`\[`float`] + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Estimator.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Estimator.mdx new file mode 100644 index 00000000000..0ff89fcbd70 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Estimator.mdx @@ -0,0 +1,14 @@ +--- +title: Estimator +description: API reference for qiskit_ibm_runtime.Estimator +in_page_toc_min_heading_level: 1 +python_api_type: attribute +python_api_name: qiskit_ibm_runtime.Estimator +--- + +# Estimator + + + alias of [`EstimatorV2`](qiskit_ibm_runtime.EstimatorV2 "qiskit_ibm_runtime.estimator.EstimatorV2") + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.EstimatorV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.EstimatorV2.mdx new file mode 100644 index 00000000000..997a7f76fcd --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.EstimatorV2.mdx @@ -0,0 +1,127 @@ +--- +title: EstimatorV2 +description: API reference for qiskit_ibm_runtime.EstimatorV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.EstimatorV2 +--- + +# EstimatorV2 + + + Class for interacting with Qiskit Runtime Estimator primitive service. + + Qiskit Runtime Estimator primitive service estimates expectation values of quantum circuits and observables. + + The [`run()`](#qiskit_ibm_runtime.EstimatorV2.run "qiskit_ibm_runtime.EstimatorV2.run") can be used to submit circuits, observables, and parameters to the Estimator primitive. + + Following construction, an estimator is used by calling its [`run()`](#qiskit_ibm_runtime.EstimatorV2.run "qiskit_ibm_runtime.EstimatorV2.run") method with a list of PUBs (Primitive Unified Blocs). Each PUB contains four values that, together, define a computation unit of work for the estimator to complete: + + * a single [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), possibly parametrized, whose final state we define as $\psi(\theta)$, + * one or more observables (specified as any `ObservablesArrayLike`, including `Pauli`, `SparsePauliOp`, `str`) that specify which expectation values to estimate, denoted $H_j$, and + * a collection parameter value sets to bind the circuit against, $\theta_k$. + * an optional target precision for expectation value estimates. + + Here is an example of how the estimator is used. + + ```python + from qiskit.circuit.library import RealAmplitudes + from qiskit.quantum_info import SparsePauliOp + from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + from qiskit_ibm_runtime import QiskitRuntimeService, EstimatorV2 as Estimator + + service = QiskitRuntimeService() + backend = service.least_busy(operational=True, simulator=False) + + psi = RealAmplitudes(num_qubits=2, reps=2) + hamiltonian = SparsePauliOp.from_list([("II", 1), ("IZ", 2), ("XI", 3)]) + theta = [0, 1, 1, 2, 3, 5] + + pm = generate_preset_pass_manager(backend=backend, optimization_level=1) + isa_psi = pm.run(psi) + isa_observables = hamiltonian.apply_layout(isa_psi.layout) + + estimator = Estimator(mode=backend) + + # calculate [ ] + job = estimator.run([(isa_psi, isa_observables, [theta])]) + pub_result = job.result()[0] + print(f"Expectation values: {pub_result.data.evs}") + ``` + + Initializes the Estimator primitive. + + **Parameters** + + * **mode** (`Union`\[[`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "(in Qiskit v1.2)"), [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)"), [`Session`](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.session.Session"), [`Batch`](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.batch.Batch"), `str`, `None`]) – + + The execution mode used to make the primitive query. It can be: + + * A `Backend` if you are using job mode. + * A [`Session`](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.Session") if you are using session execution mode. + * A [`Batch`](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.Batch") if you are using batch execution mode. + + Refer to the [Qiskit Runtime documentation](/guides/execution-modes). for more information about the `Execution modes`. + + * **options** (`Union`\[`Dict`, [`EstimatorOptions`](qiskit_ibm_runtime.options.EstimatorOptions "qiskit_ibm_runtime.options.estimator_options.EstimatorOptions"), `None`]) – Estimator options, see `EstimatorOptions` for detailed description. + + **Raises** + + **NotImplementedError** – If “q-ctrl” channel strategy is used. + + ## Attributes + + ### mode + + + Return the execution mode used by this primitive. + + **Return type** + + Optional\[[Session](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.Session") | [Batch](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.Batch")] + + **Returns** + + Mode used by this primitive, or `None` if an execution mode is not used. + + + ### options + + + Return options + + **Return type** + + `TypeVar`(`OptionsT`, bound= `BaseOptions`) + + + ### version + + + + ## Methods + + ### run + + + Submit a request to the estimator primitive. + + **Parameters** + + * **pubs** (*Iterable\[EstimatorPubLike]*) – An iterable of pub-like (primitive unified bloc) objects, such as tuples `(circuit, observables)` or `(circuit, observables, parameter_values)`. + * **precision** (*float | None*) – The target precision for expectation value estimates of each run Estimator Pub that does not specify its own precision. If None the estimator’s default precision value will be used. + + **Return type** + + [RuntimeJobV2](qiskit_ibm_runtime.RuntimeJobV2 "qiskit_ibm_runtime.RuntimeJobV2") + + **Returns** + + Submitted job. + + **Raises** + + **ValueError** – if precision value is not strictly greater than 0. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.IBMBackend.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.IBMBackend.mdx new file mode 100644 index 00000000000..25ce5498e74 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.IBMBackend.mdx @@ -0,0 +1,701 @@ +--- +title: IBMBackend +description: API reference for qiskit_ibm_runtime.IBMBackend +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.IBMBackend +--- + +# IBMBackend + + + Backend class interfacing with an IBM Quantum backend. + + + * You should not instantiate the `IBMBackend` class directly. Instead, use the methods provided by an [`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.QiskitRuntimeService") instance to retrieve and handle backends. + + + This class represents an IBM Quantum backend. Its attributes and methods provide information about the backend. For example, the [`status()`](#qiskit_ibm_runtime.IBMBackend.status "qiskit_ibm_runtime.IBMBackend.status") method returns a `BackendStatus` instance. The instance contains the `operational` and `pending_jobs` attributes, which state whether the backend is operational and also the number of jobs in the server queue for the backend, respectively: + + ```python + status = backend.status() + is_operational = status.operational + jobs_in_queue = status.pending_jobs + ``` + + Here is list of attributes available on the `IBMBackend` class: + + > * name: backend name. + > + > * backend\_version: backend version in the form X.Y.Z. + > + > * num\_qubits: number of qubits. + > + > * target: A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + > + > * basis\_gates: list of basis gates names on the backend. + > + > * gates: list of basis gates on the backend. + > + > * local: backend is local or remote. + > + > * simulator: backend is a simulator. + > + > * conditional: backend supports conditional operations. + > + > * open\_pulse: backend supports open pulse. + > + > * memory: backend supports memory. + > + > * max\_shots: maximum number of shots supported. + > + > * coupling\_map (list): The coupling map for the device + > + > * supported\_instructions (List\[str]): Instructions supported by the backend. + > + > * dynamic\_reprate\_enabled (bool): whether delay between primitives can be set dynamically (ie via `rep_delay`). Defaults to False. + > + > * rep\_delay\_range (List\[float]): 2d list defining supported range of repetition delays for backend in μs. First entry is lower end of the range, second entry is higher end of the range. Optional, but will be specified when `dynamic_reprate_enabled=True`. + > + > * default\_rep\_delay (float): Value of `rep_delay` if not specified by user and `dynamic_reprate_enabled=True`. + > + > * n\_uchannels: Number of u-channels. + > + > * u\_channel\_lo: U-channel relationship on device los. + > + > * meas\_levels: Supported measurement levels. + > + > * qubit\_lo\_range: Qubit lo ranges for each qubit with form (min, max) in GHz. + > + > * meas\_lo\_range: Measurement lo ranges for each qubit with form (min, max) in GHz. + > + > * dt: Qubit drive channel timestep in nanoseconds. + > + > * dtm: Measurement drive channel timestep in nanoseconds. + > + > * rep\_times: Supported repetition times (program execution time) for backend in μs. + > + > * meas\_kernels: Supported measurement kernels. + > + > * discriminators: Supported discriminators. + > + > * hamiltonian: An optional dictionary with fields characterizing the system hamiltonian. + > + > * channel\_bandwidth (list): Bandwidth of all channels (qubit, measurement, and U) + > + > * acquisition\_latency (list): Array of dimension n\_qubits x n\_registers. Latency (in units of dt) to write a measurement result from qubit n into register slot m. + > + > * conditional\_latency (list): Array of dimension n\_channels \[d->u->m] x n\_registers. Latency (in units of dt) to do a conditional operation on channel n from register slot m + > + > * meas\_map (list): Grouping of measurement which are multiplexed + > + > * max\_circuits (int): The maximum number of experiments per job + > + > * sample\_name (str): Sample name for the backend + > + > * n\_registers (int): Number of register slots available for feedback (if conditional is True) + > + > * register\_map (list): An array of dimension n\_qubits X n\_registers that specifies whether a qubit can store a measurement in a certain register slot. + > + > * configurable (bool): True if the backend is configurable, if the backend is a simulator + > + > * credits\_required (bool): True if backend requires credits to run a job. + > + > * online\_date (datetime): The date that the device went online + > + > * display\_name (str): Alternate name field for the backend + > + > * description (str): A description for the backend + > + > * tags (list): A list of string tags to describe the backend + > + > * version: version of `Backend` class (Ex: 1, 2) + > + > * channels: An optional dictionary containing information of each channel – their purpose, type, and qubits operated on. + > + > * parametric\_pulses (list): A list of pulse shapes which are supported on the backend. For example: `['gaussian', 'constant']` + > + > * processor\_type (dict): Processor type for this backend. A dictionary of the form `{"family": , "revision": , segment: }` such as `{"family": "Canary", "revision": "1.0", segment: "A"}`. + > + > > * family: Processor family of this backend. + > > * revision: Revision version of this processor. + > > * segment: Segment this processor belongs to within a larger chip. + + IBMBackend constructor. + + **Parameters** + + * **configuration** (`Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`]) – Backend configuration. + * **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – Instance of QiskitRuntimeService. + * **api\_client** (`RuntimeClient`) – IBM client used to communicate with the server. + + ## Attributes + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Returns** + + The output signal timestep in seconds. + + **Return type** + + dtm + + + ### id\_warning\_issued + + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + The maximum number of circuits + + The maximum number of circuits (or Pulse schedules) that can be run in a single job. If there is no limit this will return None. + + **Return type** + + `int` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The grouping of measurements which are multiplexed + + **Return type** + + meas\_map + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.IBMBackend.run "qiskit_ibm_runtime.IBMBackend.run") method. + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### service + + + Return the `service` object + + **Returns** + + instance of QiskitRuntimeService + + **Return type** + + service + + + ### session + + + Return session + + **Return type** + + `Session` + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + [`Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") + + **Returns** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### \_\_call\_\_ + + + Call self as a function. + + **Return type** + + [`IBMBackend`](#qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.ibm_backend.IBMBackend") + + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### cancel\_session + + + Cancel session. All pending jobs will be cancelled. + + **Return type** + + `None` + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### close\_session + + + Close the session so new jobs will no longer be accepted, but existing queued or running jobs will run to completion. The session will be terminated once there are no more pending jobs. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + Backend configuration contains fixed information about the backend, such as its name, number of qubits, basis gates, coupling map, quantum volume, etc. + + The schema for backend configuration can be found in [Qiskit/ibm-quantum-schemas/backend\_configuration](https://github.com/Qiskit/ibm-quantum-schemas/blob/main/schemas/backend_configuration_schema.json). + + More details about backend configuration properties can be found here [QasmBackendConfiguration](/api/qiskit/qiskit.providers.models.QasmBackendConfiguration). + + **IBM backends may also include the following properties:** + + * **`supported_features`: a list of strings of supported features like “qasm3” for dynamic** + + circuits support. + + * **`parallel_compilation`: a boolean of whether or not the backend can process multiple** + + jobs at once. Parts of the classical computation will be parallelized. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + **Returns** + + The configuration for the backend. + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend. + + The schema for default pulse configuration can be found in [Qiskit/ibm-quantum-schemas/default\_pulse\_configuration](https://github.com/Qiskit/ibm-quantum-schemas/blob/main/schemas/default_pulse_configuration_schema.json). + + **Parameters** + + **refresh** (`bool`) – If `True`, re-query the server for the backend pulse defaults. Otherwise, return a cached version. + + **Return type** + + `Optional`\[`PulseDefaults`] + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### get\_translation\_stage\_plugin + + + Return the default translation stage plugin name for IBM backends. + + **Return type** + + `str` + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### open\_session + + + Open session + + **Return type** + + `Session` + + + ### properties + + + Return the backend properties, subject to optional filtering. + + This data describes qubits properties (such as T1 and T2), gates properties (such as gate length and error), and other general properties of the backend. + + The schema for backend properties can be found in [Qiskit/ibm-quantum-schemas/backend\_properties](https://github.com/Qiskit/ibm-quantum-schemas/blob/main/schemas/backend_properties_schema.json). + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-query the server for the backend properties. Otherwise, return a cached version. + * **datetime** (`Optional`\[`datetime`]) – By specifying datetime, this function returns an instance of the `BackendProperties` whose timestamp is closest to, but older than, the specified datetime. Note that this is only supported using `ibm_quantum` runtime. + + **Return type** + + `Optional`\[`BackendProperties`] + + **Returns** + + The backend properties or `None` if the backend properties are not currently available. + + **Raises** + + * **TypeError** – If an input argument is not of the correct type. + * **NotImplementedError** – If datetime is specified when cloud runtime is used. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### run + + + Run on the backend. If a keyword specified here is also present in the `options` attribute/object, the value specified here will be used for this run. + + **Parameters** + + * **circuits** (`Union`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `str`, `List`\[`Union`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `str`]]]) – An individual or a list of `QuantumCircuit`. + + * **dynamic** (`Optional`\[`bool`]) – Whether the circuit is dynamic (uses in-circuit conditionals) + + * **job\_tags** (`Optional`\[`List`\[`str`]]) – Tags to be assigned to the job. The tags can subsequently be used as a filter in the `jobs()` function call. + + * **init\_circuit** (`Optional`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")]) – A quantum circuit to execute for initializing qubits before each circuit. If specified, `init_num_resets` is ignored. Applicable only if `dynamic=True` is specified. + + * **init\_num\_resets** (`Optional`\[`int`]) – The number of qubit resets to insert before each circuit execution. + + * **header** (`Optional`\[`Dict`]) – User input that will be attached to the job and will be copied to the corresponding result header. Headers do not affect the run. This replaces the old `Qobj` header. This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **shots** (`Union`\[`int`, `float`, `None`]) – Number of repetitions of each circuit, for sampling. Default: 4000 or `max_shots` from the backend configuration, whichever is smaller. This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **memory** (`Optional`\[`bool`]) – If `True`, per-shot measurement bitstrings are returned as well (provided the backend supports it). For OpenPulse jobs, only measurement level 2 supports this option. This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **meas\_level** (`Union`\[`int`, `MeasLevel`, `None`]) – + + Level of the measurement output for pulse experiments. See [OpenPulse specification](https://arxiv.org/pdf/1809.03452.pdf) for details: + + * `0`, measurements of the raw signal (the measurement output pulse envelope) + * `1`, measurement kernel is selected (a complex number obtained after applying the measurement kernel to the measurement output signal) + * `2` (default), a discriminator is selected and the qubit state is stored (0 or 1) + + This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **meas\_return** (`Union`\[`str`, `MeasReturnType`, `None`]) – + + Level of measurement data for the backend to return. For `meas_level` 0 and 1: + + * `single` returns information from every shot. + * `avg` returns average measurement output (averaged over number of shots). + + This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **rep\_delay** (`Optional`\[`float`]) – Delay between primitives in seconds. Only supported on certain backends (if `backend.configuration().dynamic_reprate_enabled=True`). If supported, `rep_delay` must be from the range supplied by the backend (`backend.configuration().rep_delay_range`). Default is given by `backend.configuration().default_rep_delay`. This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **init\_qubits** (`Optional`\[`bool`]) – Whether to reset the qubits to the ground state for each shot. Default: `True`. This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **use\_measure\_esp** (`Optional`\[`bool`]) – Whether to use excited state promoted (ESP) readout for measurements which are the terminal instruction to a qubit. ESP readout can offer higher fidelity than standard measurement sequences. See [here](https://arxiv.org/pdf/2008.08571.pdf). Default: `True` if backend supports ESP readout, else `False`. Backend support for ESP readout is determined by the flag `measure_esp_enabled` in `backend.configuration()`. This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **noise\_model** (`Optional`\[`Any`]) – Noise model (Simulators only). This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **seed\_simulator** (`Optional`\[`int`]) – Random seed to control sampling (Simulators only). This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + * **\*\*run\_config** – Extra arguments used to configure the run. This parameter is applicable only if `dynamic=False` is specified or defaulted to. + + **Return type** + + [`RuntimeJob`](qiskit_ibm_runtime.RuntimeJob "qiskit_ibm_runtime.runtime_job.RuntimeJob") + + **Returns** + + The job to be executed. + + **Raises** + + * **IBMBackendApiError** – If an unexpected error occurred while submitting the job. + + * **IBMBackendApiProtocolError** – If an unexpected value received from the server. + + * **IBMBackendValueError** – + + * If an input parameter value is not valid. - If ESP readout is used and the backend does not support this. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + + If the returned `BackendStatus` instance has `operational=True` but `status_msg="internal"`, then the backend is accepting jobs but not processing them. + + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + **Raises** + + **IBMBackendApiProtocolError** – If the status for the backend cannot be formatted properly. + + + ### target\_history + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + [`Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") + + **Returns** + + Target with properties found on datetime + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.QiskitRuntimeService.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.QiskitRuntimeService.mdx new file mode 100644 index 00000000000..454df61c788 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.QiskitRuntimeService.mdx @@ -0,0 +1,391 @@ +--- +title: QiskitRuntimeService +description: API reference for qiskit_ibm_runtime.QiskitRuntimeService +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.QiskitRuntimeService +--- + +# QiskitRuntimeService + + + Class for interacting with the Qiskit Runtime service. + + QiskitRuntimeService constructor + + An account is selected in the following order: + + > * Account with the input name, if specified. + > * Default account for the channel type, if channel is specified but token is not. + > * Account defined by the input channel and token, if specified. + > * Account defined by the default\_channel if defined in filename + > * Account defined by the environment variables, if defined. + > * Default account for the `ibm_cloud` account, if one is available. + > * Default account for the `ibm_quantum` account, if one is available. + + instance, proxies, and verify can be used to overwrite corresponding values in the loaded account. + + **Parameters** + + * **channel** (`Optional`\[`Literal`\[‘ibm\_cloud’, ‘ibm\_quantum’, ‘local’]]) – Channel type. `ibm_cloud`, `ibm_quantum` or `local`. If `local` is selected, the local testing mode will be used, and primitive queries will run on a local simulator. For more details, check the [Qiskit Runtime local testing mode](/guides/local-testing-mode) documentation. + * **token** (`Optional`\[`str`]) – IBM Cloud API key or IBM Quantum API token. + * **url** (`Optional`\[`str`]) – The API URL. Defaults to [https://cloud.ibm.com](https://cloud.ibm.com) (ibm\_cloud) or [https://auth.quantum-computing.ibm.com/api](https://auth.quantum-computing.ibm.com/api) (ibm\_quantum). + * **filename** (`Optional`\[`str`]) – Full path of the file where the account is created. Default: \_DEFAULT\_ACCOUNT\_CONFIG\_JSON\_FILE + * **name** (`Optional`\[`str`]) – Name of the account to load. + * **instance** (`Optional`\[`str`]) – The service instance to use. For `ibm_cloud` runtime, this is the Cloud Resource Name (CRN) or the service name. For `ibm_quantum` runtime, this is the hub/group/project in that format. + * **proxies** (`Optional`\[`dict`]) – Proxy configuration. Supported optional keys are `urls` (a dictionary mapping protocol or protocol and host to the URL of the proxy, documented at [https://docs.python-requests.org/en/latest/api/#requests.Session.proxies](https://docs.python-requests.org/en/latest/api/#requests.Session.proxies)), `username_ntlm`, `password_ntlm` (username and password to enable NTLM user authentication) + * **verify** (`Optional`\[`bool`]) – Whether to verify the server’s TLS certificate. + * **channel\_strategy** (`Optional`\[`str`]) – (DEPRECATED) Error mitigation strategy. + * **private\_endpoint** (`Optional`\[`bool`]) – Connect to private API URL. + * **url\_resolver** (`Optional`\[`Callable`\[\[`str`, `str`, `Optional`\[`bool`]], `str`]]) – Function used to resolve the runtime url. + + **Returns** + + An instance of QiskitRuntimeService or QiskitRuntimeLocalService for local channel. + + **Raises** + + **IBMInputValueError** – If an input is invalid. + + ## Attributes + + ### channel + + + Return the channel type used. + + **Return type** + + `str` + + **Returns** + + The channel type used. + + + ### global\_service + + + + ## Methods + + ### active\_account + + + Return the IBM Quantum account currently in use for the session. + + **Return type** + + `Optional`\[`Dict`\[`str`, `str`]] + + **Returns** + + A dictionary with information about the account currently in the session. + + + ### backend + + + Return a single backend matching the specified filtering. + + **Parameters** + + * **name** (`str`) – Name of the backend. + * **instance** (`Optional`\[`str`]) – This is only supported for `ibm_quantum` runtime and is in the hub/group/project format. If an instance is not given, among the providers with access to the backend, a premium provider will be prioritized. For users without access to a premium provider, the default open provider will be used. + * **use\_fractional\_gates** (`Optional`\[`bool`]) – Set True to allow for the backends to include fractional gates in target. Currently this feature cannot be used simulataneously with dynamic circuits, PEC, PEA, or gate twirling. When this flag is set, control flow instructions are automatically removed from the backend target. When you use the dynamic circuits feature (e.g. if\_else) in your algorithm, you must disable this flag to create executable ISA circuits. This flag might be modified or removed when our backend supports dynamic circuits and fractional gates simultaneously. If `None`, then both fractional gates and control flow operations are included in the backend targets. + + **Returns** + + A backend matching the filtering. + + **Return type** + + Backend + + **Raises** + + **QiskitBackendNotFoundError** – if no backend could be found. + + + ### backends + + + Return all backends accessible via this account, subject to optional filtering. + + **Parameters** + + * **name** (`Optional`\[`str`]) – Backend name to filter by. + + * **min\_num\_qubits** (`Optional`\[`int`]) – Minimum number of qubits the backend has to have. + + * **instance** (`Optional`\[`str`]) – This is only supported for `ibm_quantum` runtime and is in the hub/group/project format. + + * **dynamic\_circuits** (`Optional`\[`bool`]) – Filter by whether the backend supports dynamic circuits. + + * **filters** (`Optional`\[`Callable`\[\[[`IBMBackend`](qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.ibm_backend.IBMBackend")], `bool`]]) – + + More complex filters, such as lambda functions. For example: + + ```python + QiskitRuntimeService.backends( + filters=lambda b: b.max_shots > 50000 + ) + QiskitRuntimeService.backends( + filters=lambda x: ("rz" in x.basis_gates ) + ) + ``` + + * **use\_fractional\_gates** (`Optional`\[`bool`]) – Set True to allow for the backends to include fractional gates in target. Currently this feature cannot be used simulataneously with dynamic circuits, PEC, PEA, or gate twirling. When this flag is set, control flow instructions are automatically removed from the backend target. When you use the dynamic circuits feature (e.g. if\_else) in your algorithm, you must disable this flag to create executable ISA circuits. This flag might be modified or removed when our backend supports dynamic circuits and fractional gates simultaneously. If `None`, then both fractional gates and control flow operations are included in the backend targets. + + * **\*\*kwargs** – + + Simple filters that require a specific value for an attribute in backend configuration or status. Examples: + + ```python + # Get the operational real backends + QiskitRuntimeService.backends(simulator=False, operational=True) + + # Get the backends with at least 127 qubits + QiskitRuntimeService.backends(min_num_qubits=127) + + # Get the backends that support OpenPulse + QiskitRuntimeService.backends(open_pulse=True) + ``` + + For the full list of backend attributes, see the IBMBackend class documentation \<[api/qiskit/providers\_models](/api/qiskit/providers_models)> + + **Return type** + + `List`\[[`IBMBackend`](qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.ibm_backend.IBMBackend")] + + **Returns** + + The list of available backends that match the filter. + + **Raises** + + * **IBMInputValueError** – If an input is invalid. + * **QiskitBackendNotFoundError** – If the backend is not in any instance. + + + ### check\_pending\_jobs + + + Check the number of pending jobs and wait for the oldest pending job if the maximum number of pending jobs has been reached. + + **Return type** + + `None` + + + ### delete\_account + + + Delete a saved account from disk. + + **Parameters** + + * **filename** (`Optional`\[`str`]) – Name of file from which to delete the account. + * **name** (`Optional`\[`str`]) – Name of the saved account to delete. + * **channel** (`Optional`\[`Literal`\[‘ibm\_cloud’, ‘ibm\_quantum’, ‘local’]]) – Channel type of the default account to delete. Ignored if account name is provided. + + **Return type** + + `bool` + + **Returns** + + True if the account was deleted. False if no account was found. + + + ### delete\_job + + + Delete a runtime job. + + Note that this operation cannot be reversed. + + **Parameters** + + **job\_id** (`str`) – ID of the job to delete. + + **Raises** + + * **RuntimeJobNotFound** – If the job doesn’t exist. + * **IBMRuntimeError** – If the request failed. + + **Return type** + + `None` + + + ### instances + + + Return the IBM Quantum instances list currently in use for the session. + + **Return type** + + `List`\[`str`] + + **Returns** + + A list with instances currently in the session. + + + ### job + + + Retrieve a runtime job. + + **Parameters** + + **job\_id** (`str`) – Job ID. + + **Return type** + + `Union`\[[`RuntimeJob`](qiskit_ibm_runtime.RuntimeJob "qiskit_ibm_runtime.runtime_job.RuntimeJob"), [`RuntimeJobV2`](qiskit_ibm_runtime.RuntimeJobV2 "qiskit_ibm_runtime.runtime_job_v2.RuntimeJobV2")] + + **Returns** + + Runtime job retrieved. + + **Raises** + + * **RuntimeJobNotFound** – If the job doesn’t exist. + * **IBMRuntimeError** – If the request failed. + + + ### jobs + + + Retrieve all runtime jobs, subject to optional filtering. + + **Parameters** + + * **limit** (`Optional`\[`int`]) – Number of jobs to retrieve. `None` means no limit. + * **skip** (`int`) – Starting index for the job retrieval. + * **backend\_name** (`Optional`\[`str`]) – Name of the backend to retrieve jobs from. + * **pending** (`Optional`\[`bool`]) – Filter by job pending state. If `True`, ‘QUEUED’ and ‘RUNNING’ jobs are included. If `False`, ‘DONE’, ‘CANCELLED’ and ‘ERROR’ jobs are included. + * **program\_id** (`Optional`\[`str`]) – Filter by Program ID. + * **instance** (`Optional`\[`str`]) – This is only supported for `ibm_quantum` runtime and is in the hub/group/project format. + * **job\_tags** (`Optional`\[`List`\[`str`]]) – Filter by tags assigned to jobs. Matched jobs are associated with all tags. + * **session\_id** (`Optional`\[`str`]) – Job ID of the first job in a runtime session. + * **created\_after** (`Optional`\[`datetime`]) – Filter by the given start date, in local time. This is used to find jobs whose creation dates are after (greater than or equal to) this local date/time. + * **created\_before** (`Optional`\[`datetime`]) – Filter by the given end date, in local time. This is used to find jobs whose creation dates are before (less than or equal to) this local date/time. + * **descending** (`bool`) – If `True`, return the jobs in descending order of the job creation date (i.e. newest first) until the limit is reached. + + **Return type** + + `List`\[`Union`\[[`RuntimeJob`](qiskit_ibm_runtime.RuntimeJob "qiskit_ibm_runtime.runtime_job.RuntimeJob"), [`RuntimeJobV2`](qiskit_ibm_runtime.RuntimeJobV2 "qiskit_ibm_runtime.runtime_job_v2.RuntimeJobV2")]] + + **Returns** + + A list of runtime jobs. + + **Raises** + + **IBMInputValueError** – If an input value is invalid. + + + ### least\_busy + + + Return the least busy available backend. + + **Parameters** + + * **min\_num\_qubits** (`Optional`\[`int`]) – Minimum number of qubits the backend has to have. + + * **instance** (`Optional`\[`str`]) – This is only supported for `ibm_quantum` runtime and is in the hub/group/project format. + + * **filters** (`Optional`\[`Callable`\[\[[`IBMBackend`](qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.ibm_backend.IBMBackend")], `bool`]]) – + + Filters can be defined as for the [`backends()`](#qiskit_ibm_runtime.QiskitRuntimeService.backends "qiskit_ibm_runtime.QiskitRuntimeService.backends") method. An example to get the operational backends with 5 qubits: + + ```python + QiskitRuntimeService.least_busy(n_qubits=5, operational=True) + ``` + + **Return type** + + [`IBMBackend`](qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.ibm_backend.IBMBackend") + + **Returns** + + The backend with the fewest number of pending jobs. + + **Raises** + + **QiskitBackendNotFoundError** – If no backend matches the criteria. + + + ### save\_account + + + Save the account to disk for future use. + + **Parameters** + + * **token** (`Optional`\[`str`]) – IBM Cloud API key or IBM Quantum API token. + * **url** (`Optional`\[`str`]) – The API URL. Defaults to [https://cloud.ibm.com](https://cloud.ibm.com) (ibm\_cloud) or [https://auth.quantum-computing.ibm.com/api](https://auth.quantum-computing.ibm.com/api) (ibm\_quantum). + * **instance** (`Optional`\[`str`]) – The CRN (ibm\_cloud) or hub/group/project (ibm\_quantum). + * **channel** (`Optional`\[`Literal`\[‘ibm\_cloud’, ‘ibm\_quantum’, ‘local’]]) – Channel type. ibm\_cloud or ibm\_quantum. + * **filename** (`Optional`\[`str`]) – Full path of the file where the account is saved. + * **name** (`Optional`\[`str`]) – Name of the account to save. + * **proxies** (`Optional`\[`dict`]) – Proxy configuration. Supported optional keys are `urls` (a dictionary mapping protocol or protocol and host to the URL of the proxy, documented at [https://docs.python-requests.org/en/latest/api/#requests.Session.proxies](https://docs.python-requests.org/en/latest/api/#requests.Session.proxies)), `username_ntlm`, `password_ntlm` (username and password to enable NTLM user authentication) + * **verify** (`Optional`\[`bool`]) – Verify the server’s TLS certificate. + * **overwrite** (`Optional`\[`bool`]) – `True` if the existing account is to be overwritten. + * **channel\_strategy** (`Optional`\[`str`]) – (DEPRECATED) Error mitigation strategy. + * **set\_as\_default** (`Optional`\[`bool`]) – If `True`, the account is saved in filename, as the default account. + * **private\_endpoint** (`Optional`\[`bool`]) – Connect to private API URL. + + **Return type** + + `None` + + + ### saved\_accounts + + + List the accounts saved on disk. + + **Parameters** + + * **default** (`Optional`\[`bool`]) – If set to True, only default accounts are returned. + * **channel** (`Optional`\[`Literal`\[‘ibm\_cloud’, ‘ibm\_quantum’, ‘local’]]) – Channel type. ibm\_cloud or ibm\_quantum. + * **filename** (`Optional`\[`str`]) – Name of file whose accounts are returned. + * **name** (`Optional`\[`str`]) – If set, only accounts with the given name are returned. + + **Return type** + + `dict` + + **Returns** + + A dictionary with information about the accounts saved on disk. + + **Raises** + + **ValueError** – If an invalid account is found on disk. + + + ### usage + + + Return monthly open plan usage information. + + **Return type** + + `Dict`\[`str`, `Any`] + + **Returns** + + Dict with usage details. + + **Raises** + + **IBMInputValueError** – If method is called when using the ibm\_cloud channel + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeDecoder.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeDecoder.mdx new file mode 100644 index 00000000000..8ff0f862699 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeDecoder.mdx @@ -0,0 +1,52 @@ +--- +title: RuntimeDecoder +description: API reference for qiskit_ibm_runtime.RuntimeDecoder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.RuntimeDecoder +--- + +# RuntimeDecoder + + + JSON Decoder used by runtime service. + + `object_hook`, if specified, will be called with the result of every JSON object decoded and its return value will be used in place of the given `dict`. This can be used to provide custom deserializations (e.g. to support JSON-RPC class hinting). + + `object_pairs_hook`, if specified will be called with the result of every JSON object decoded with an ordered list of pairs. The return value of `object_pairs_hook` will be used instead of the `dict`. This feature can be used to implement custom decoders. If `object_hook` is also defined, the `object_pairs_hook` takes priority. + + `parse_float`, if specified, will be called with the string of every JSON float to be decoded. By default this is equivalent to float(num\_str). This can be used to use another datatype or parser for JSON floats (e.g. decimal.Decimal). + + `parse_int`, if specified, will be called with the string of every JSON int to be decoded. By default this is equivalent to int(num\_str). This can be used to use another datatype or parser for JSON integers (e.g. float). + + `parse_constant`, if specified, will be called with one of the following strings: -Infinity, Infinity, NaN. This can be used to raise an exception if invalid JSON numbers are encountered. + + If `strict` is false (true is the default), then control characters will be allowed inside strings. Control characters in this context are those with character codes in the 0-31 range, including `'\t'` (tab), `'\n'`, `'\r'` and `'\0'`. + + ## Methods + + ### decode + + + Return the Python representation of `s` (a `str` instance containing a JSON document). + + + ### object\_hook + + + Called to decode object. + + **Return type** + + `Any` + + + ### raw\_decode + + + Decode a JSON document from `s` (a `str` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in `s` where the document ended. + + This can be used to decode a JSON document from a string that may have extraneous data at the end. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeEncoder.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeEncoder.mdx new file mode 100644 index 00000000000..12811df1999 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeEncoder.mdx @@ -0,0 +1,93 @@ +--- +title: RuntimeEncoder +description: API reference for qiskit_ibm_runtime.RuntimeEncoder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.RuntimeEncoder +--- + +# RuntimeEncoder + + + JSON Encoder used by runtime service. + + Constructor for JSONEncoder, with sensible defaults. + + If skipkeys is false, then it is a TypeError to attempt encoding of keys that are not str, int, float or None. If skipkeys is True, such items are simply skipped. + + If ensure\_ascii is true, the output is guaranteed to be str objects with all incoming non-ASCII characters escaped. If ensure\_ascii is false, the output can contain non-ASCII characters. + + If check\_circular is true, then lists, dicts, and custom encoded objects will be checked for circular references during encoding to prevent an infinite recursion (which would cause an RecursionError). Otherwise, no such check takes place. + + If allow\_nan is true, then NaN, Infinity, and -Infinity will be encoded as such. This behavior is not JSON specification compliant, but is consistent with most JavaScript based encoders and decoders. Otherwise, it will be a ValueError to encode such floats. + + If sort\_keys is true, then the output of dictionaries will be sorted by key; this is useful for regression tests to ensure that JSON serializations can be compared on a day-to-day basis. + + If indent is a non-negative integer, then JSON array elements and object members will be pretty-printed with that indent level. An indent level of 0 will only insert newlines. None is the most compact representation. + + If specified, separators should be an (item\_separator, key\_separator) tuple. The default is (’, ‘, ‘: ‘) if *indent* is `None` and (‘,’, ‘: ‘) otherwise. To get the most compact JSON representation, you should specify (‘,’, ‘:’) to eliminate whitespace. + + If specified, default is a function that gets called for objects that can’t otherwise be serialized. It should return a JSON encodable version of the object or raise a `TypeError`. + + ## Attributes + + ### item\_separator + + + + ### key\_separator + + + + ## Methods + + ### default + + + Implement this method in a subclass such that it returns a serializable object for `o`, or calls the base implementation (to raise a `TypeError`). + + For example, to support arbitrary iterators, you could implement default like this: + + ```python + def default(self, o): + try: + iterable = iter(o) + except TypeError: + pass + else: + return list(iterable) + # Let the base class default method raise the TypeError + return JSONEncoder.default(self, o) + ``` + + **Return type** + + `Any` + + + ### encode + + + Return a JSON string representation of a Python data structure. + + ```python + >>> from json.encoder import JSONEncoder + >>> JSONEncoder().encode({"foo": ["bar", "baz"]}) + '{"foo": ["bar", "baz"]}' + ``` + + + ### iterencode + + + Encode the given object and yield each string representation as available. + + For example: + + ```python + for chunk in JSONEncoder().iterencode(bigobject): + mysocket.write(chunk) + ``` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJob.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJob.mdx new file mode 100644 index 00000000000..b88bfd635be --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJob.mdx @@ -0,0 +1,539 @@ +--- +title: RuntimeJob +description: API reference for qiskit_ibm_runtime.RuntimeJob +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.RuntimeJob +--- + +# RuntimeJob + + + Representation of a runtime primitive execution. + + A new `RuntimeJob` instance is returned when you call `QiskitRuntimeService.run` to execute a runtime primitive, or [`QiskitRuntimeService.job`](qiskit_ibm_runtime.QiskitRuntimeService#job "qiskit_ibm_runtime.QiskitRuntimeService.job") to retrieve a previously executed job. + + If the primitive execution is successful, you can inspect the job’s status by calling [`status()`](#qiskit_ibm_runtime.RuntimeJob.status "qiskit_ibm_runtime.RuntimeJob.status"). Job status can be one of the [`JobStatus`](/api/qiskit/qiskit.providers.JobStatus "(in Qiskit v1.2)") members. + + Some of the methods in this class are blocking, which means control may not be returned immediately. [`result()`](#qiskit_ibm_runtime.RuntimeJob.result "qiskit_ibm_runtime.RuntimeJob.result") is an example of a blocking method: + + ```python + job = service.run(...) + + try: + job_result = job.result() # It will block until the job finishes. + print("The job finished with result {}".format(job_result)) + except RuntimeJobFailureError as ex: + print("Job failed!: {}".format(ex)) + ``` + + If the primitive has any interim results, you can use the `callback` parameter of the `run()` method to stream the interim results along with the final result. Alternatively, you can use the [`stream_results()`](#qiskit_ibm_runtime.RuntimeJob.stream_results "qiskit_ibm_runtime.RuntimeJob.stream_results") method to stream the results at a later time, but before the job finishes. + + RuntimeJob constructor. + + **Parameters** + + * **backend** ([`Backend`](/api/qiskit/qiskit.providers.Backend "(in Qiskit v1.2)")) – The backend instance used to run this job. + * **api\_client** (`RuntimeClient`) – Object for connecting to the server. + * **client\_params** (`ClientParameters`) – Parameters used for server connection. + * **job\_id** (`str`) – Job ID. + * **program\_id** (`str`) – ID of the program this job is for. + * **creation\_date** (`Optional`\[`str`]) – Job creation date, in UTC. + * **user\_callback** (`Optional`\[`Callable`]) – User callback function. + * **result\_decoder** (`Union`\[`Type`\[`ResultDecoder`], `Sequence`\[`Type`\[`ResultDecoder`]], `None`]) – A `ResultDecoder` subclass used to decode job results. + * **image** (`Optional`\[`str`]) – Runtime image used for this job: image\_name:tag. + * **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – Runtime service. + * **session\_id** (`Optional`\[`str`]) – Job ID of the first job in a runtime session. + * **tags** (`Optional`\[`List`]) – Tags assigned to the job. + * **version** (`Optional`\[`int`]) – Primitive version. + + ## Attributes + + ### ERROR + + + + ### JOB\_FINAL\_STATES + + + + ### creation\_date + + + Job creation date in local time. + + **Return type** + + `Optional`\[`datetime`] + + **Returns** + + The job creation date as a datetime object, in local time, or `None` if creation date is not available. + + + ### image + + + Return the runtime image used for the job. + + **Returns** + + image\_name:tag or “” if the default image is used. + + **Return type** + + Runtime image + + + ### inputs + + + Job input parameters. + + **Return type** + + `Dict` + + **Returns** + + Input parameters used in this job. + + + ### instance + + + For ibm\_quantum channel jobs, return the instance where the job was run. For ibm\_cloud, None is returned. + + **Return type** + + `Optional`\[`str`] + + + ### primitive\_id + + + Primitive name. :rtype: `str` :returns: Primitive this job is for. + + + ### session\_id + + + Session ID. + + **Return type** + + `str` + + **Returns** + + Session ID. None if the backend is a simulator. + + + ### tags + + + Job tags. + + **Return type** + + `List` + + **Returns** + + Tags assigned to the job that can be used for filtering. + + + ### usage\_estimation + + + Return the usage estimation infromation for this job. + + **Return type** + + `Dict`\[`str`, `Any`] + + **Returns** + + `quantum_seconds` which is the estimated system execution time of the job in seconds. Quantum time represents the time that the system is dedicated to processing your job. + + + ### version + + + + ## Methods + + ### backend + + + Return the backend where this job was executed. Retrieve data again if backend is None. + + **Raises** + + **IBMRuntimeError** – If a network error occurred. + + **Return type** + + `Optional`\[[`Backend`](/api/qiskit/qiskit.providers.Backend "(in Qiskit v1.2)")] + + + ### cancel + + + Cancel the job. + + **Raises** + + * **RuntimeInvalidStateError** – If the job is in a state that cannot be cancelled. + * **IBMRuntimeError** – If unable to cancel job. + + **Return type** + + `None` + + + ### cancel\_result\_streaming + + + Cancel result streaming. + + **Return type** + + `None` + + + ### cancelled + + + Return whether the job has been cancelled. + + **Return type** + + `bool` + + + ### done + + + Return whether the job has successfully run. + + **Return type** + + `bool` + + + ### error\_message + + + Returns the reason if the job failed. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Error message string or `None`. + + + ### errored + + + Return whether the job has failed. + + **Return type** + + `bool` + + + ### in\_final\_state + + + Return whether the job is in a final job state such as `DONE` or `ERROR`. + + **Return type** + + `bool` + + + ### interim\_results + + + (DEPRECATED) Return the interim results of the job. + + **Parameters** + + **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode interim results. + + **Return type** + + `Any` + + **Returns** + + Runtime job interim results. + + **Raises** + + **RuntimeJobFailureError** – If the job failed. + + + ### job\_id + + + Return a unique id identifying the job. + + **Return type** + + `str` + + + ### logs + + + Return job logs. + + + Job logs are only available after the job finishes. + + + **Return type** + + `str` + + **Returns** + + Job logs, including standard output and error. + + **Raises** + + **IBMRuntimeError** – If a network error occurred. + + + ### metrics + + + Return job metrics. + + **Returns** + + * `timestamps`: Timestamps of when the job was created, started running, and finished. + + * **`usage`: Details regarding job usage, the measurement of the amount of** + + time the QPU is locked for your workload. + + **Return type** + + A dictionary with job metrics including but not limited to the following + + **Raises** + + **IBMRuntimeError** – If a network error occurred. + + + ### properties + + + Return the backend properties for this job. + + **Parameters** + + **refresh** (`bool`) – If `True`, re-query the server for the backend properties. Otherwise, return a cached version. + + **Return type** + + `Optional`\[`BackendProperties`] + + **Returns** + + The backend properties used for this job, at the time the job was run, or `None` if properties are not available. + + + ### queue\_info + + + Return queue information for this job. + + The queue information may include queue position, estimated start and end time, and dynamic priorities for the hub, group, and project. See `QueueInfo` for more information. + + + The queue information is calculated after the job enters the queue. Therefore, some or all of the information may not be immediately available, and this method may return `None`. + + + **Return type** + + `Optional`\[`QueueInfo`] + + **Returns** + + A `QueueInfo` instance that contains queue information for this job, or `None` if queue information is unknown or not applicable. + + + ### queue\_position + + + Return the position of the job in the server queue. + + + The position returned is within the scope of the provider and may differ from the global queue position. + + + **Parameters** + + **refresh** (`bool`) – If `True`, re-query the server to get the latest value. Otherwise return the cached value. + + **Return type** + + `Optional`\[`int`] + + **Returns** + + Position in the queue or `None` if position is unknown or not applicable. + + + ### result + + + Return the results of the job. + + **Parameters** + + * **timeout** (`Optional`\[`float`]) – Number of seconds to wait for job. + * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. + + **Return type** + + `Any` + + **Returns** + + Runtime job result. + + **Raises** + + * **RuntimeJobFailureError** – If the job failed. + * **RuntimeJobMaxTimeoutError** – If the job does not complete within given timeout. + * **RuntimeInvalidStateError** – If the job was cancelled, and attempting to retrieve result. + + + ### running + + + Return whether the job is actively running. + + **Return type** + + `bool` + + + ### status + + + Return the status of the job. + + **Return type** + + [`JobStatus`](/api/qiskit/qiskit.providers.JobStatus "(in Qiskit v1.2)") + + **Returns** + + Status of this job. + + + ### stream\_results + + + (DEPRECATED) Start streaming job results. + + **Parameters** + + * **callback** (`Callable`) – + + Callback function to be invoked for any interim results and final result. The callback function will receive 2 positional parameters: + + > 1. Job ID + > 2. Job result. + + * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. + + **Raises** + + **RuntimeInvalidStateError** – If a callback function is already streaming results or if the job already finished. + + **Return type** + + `None` + + + ### submit + + + Unsupported method. .. note: + + ```python + This method is not supported, please use + :meth:`~qiskit_ibm_runtime.QiskitRuntimeService.run` + to submit a job. + ``` + + **Raises** + + **NotImplementedError** – Upon invocation. + + **Return type** + + `None` + + + ### update\_tags + + + Update the tags associated with this job. + + **Parameters** + + **new\_tags** (`List`\[`str`]) – New tags to assign to the job. + + **Return type** + + `List`\[`str`] + + **Returns** + + The new tags associated with this job. + + **Raises** + + **IBMApiError** – If an unexpected error occurred when communicating with the server or updating the job tags. + + + ### usage + + + Return job usage in seconds. + + **Return type** + + `float` + + + ### wait\_for\_final\_state + + + Poll for the job status from the API until the status is in a final state. + + **Parameters** + + **timeout** (`Optional`\[`float`]) – Seconds to wait for the job. If `None`, wait indefinitely. + + **Raises** + + **RuntimeJobTimeoutError** – If the job does not complete within given timeout. + + **Return type** + + `None` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJobV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJobV2.mdx new file mode 100644 index 00000000000..c4347d7223b --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.RuntimeJobV2.mdx @@ -0,0 +1,455 @@ +--- +title: RuntimeJobV2 +description: API reference for qiskit_ibm_runtime.RuntimeJobV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.RuntimeJobV2 +--- + +# RuntimeJobV2 + + + Representation of a runtime V2 primitive exeuction. + + RuntimeJob constructor. + + **Parameters** + + * **backend** ([`Backend`](/api/qiskit/qiskit.providers.Backend "(in Qiskit v1.2)")) – The backend instance used to run this job. + * **api\_client** (`RuntimeClient`) – Object for connecting to the server. + * **client\_params** (`ClientParameters`) – Parameters used for server connection. + * **job\_id** (`str`) – Job ID. + * **program\_id** (`str`) – ID of the program this job is for. + * **creation\_date** (`Optional`\[`str`]) – Job creation date, in UTC. + * **user\_callback** (`Optional`\[`Callable`]) – User callback function. + * **result\_decoder** (`Union`\[`Type`\[`ResultDecoder`], `Sequence`\[`Type`\[`ResultDecoder`]], `None`]) – A `ResultDecoder` subclass used to decode job results. + * **image** (`Optional`\[`str`]) – Runtime image used for this job: image\_name:tag. + * **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – Runtime service. + * **session\_id** (`Optional`\[`str`]) – Job ID of the first job in a runtime session. + * **tags** (`Optional`\[`List`]) – Tags assigned to the job. + * **version** (`Optional`\[`int`]) – Primitive version. + + ## Attributes + + ### ERROR + + + + ### JOB\_FINAL\_STATES + + + + ### creation\_date + + + Job creation date in local time. + + **Return type** + + `Optional`\[`datetime`] + + **Returns** + + The job creation date as a datetime object, in local time, or `None` if creation date is not available. + + + ### image + + + Return the runtime image used for the job. + + **Returns** + + image\_name:tag or “” if the default image is used. + + **Return type** + + Runtime image + + + ### inputs + + + Job input parameters. + + **Return type** + + `Dict` + + **Returns** + + Input parameters used in this job. + + + ### instance + + + For ibm\_quantum channel jobs, return the instance where the job was run. For ibm\_cloud, None is returned. + + **Return type** + + `Optional`\[`str`] + + + ### primitive\_id + + + Primitive name. :rtype: `str` :returns: Primitive this job is for. + + + ### session\_id + + + Session ID. + + **Return type** + + `str` + + **Returns** + + Session ID. None if the backend is a simulator. + + + ### tags + + + Job tags. + + **Return type** + + `List` + + **Returns** + + Tags assigned to the job that can be used for filtering. + + + ### usage\_estimation + + + Return the usage estimation infromation for this job. + + **Return type** + + `Dict`\[`str`, `Any`] + + **Returns** + + `quantum_seconds` which is the estimated system execution time of the job in seconds. Quantum time represents the time that the system is dedicated to processing your job. + + + ## Methods + + ### backend + + + Return the backend where this job was executed. Retrieve data again if backend is None. + + **Raises** + + **IBMRuntimeError** – If a network error occurred. + + **Return type** + + `Optional`\[[`Backend`](/api/qiskit/qiskit.providers.Backend "(in Qiskit v1.2)")] + + + ### cancel + + + Cancel the job. + + **Raises** + + * **RuntimeInvalidStateError** – If the job is in a state that cannot be cancelled. + * **IBMRuntimeError** – If unable to cancel job. + + **Return type** + + `None` + + + ### cancel\_result\_streaming + + + Cancel result streaming. + + **Return type** + + `None` + + + ### cancelled + + + Return whether the job has been cancelled. + + **Return type** + + `bool` + + + ### done + + + Return whether the job has successfully run. + + **Return type** + + `bool` + + + ### error\_message + + + Returns the reason if the job failed. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Error message string or `None`. + + + ### errored + + + Return whether the job has failed. + + **Return type** + + `bool` + + + ### in\_final\_state + + + Return whether the job is in a final job state such as `DONE` or `ERROR`. + + **Return type** + + `bool` + + + ### interim\_results + + + (DEPRECATED) Return the interim results of the job. + + **Parameters** + + **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode interim results. + + **Return type** + + `Any` + + **Returns** + + Runtime job interim results. + + **Raises** + + **RuntimeJobFailureError** – If the job failed. + + + ### job\_id + + + Return a unique id identifying the job. + + **Return type** + + `str` + + + ### logs + + + Return job logs. + + + Job logs are only available after the job finishes. + + + **Return type** + + `str` + + **Returns** + + Job logs, including standard output and error. + + **Raises** + + **IBMRuntimeError** – If a network error occurred. + + + ### metrics + + + Return job metrics. + + **Returns** + + * `timestamps`: Timestamps of when the job was created, started running, and finished. + + * **`usage`: Details regarding job usage, the measurement of the amount of** + + time the QPU is locked for your workload. + + **Return type** + + A dictionary with job metrics including but not limited to the following + + **Raises** + + **IBMRuntimeError** – If a network error occurred. + + + ### properties + + + Return the backend properties for this job. + + **Parameters** + + **refresh** (`bool`) – If `True`, re-query the server for the backend properties. Otherwise, return a cached version. + + **Return type** + + `Optional`\[`BackendProperties`] + + **Returns** + + The backend properties used for this job, at the time the job was run, or `None` if properties are not available. + + + ### result + + + Return the results of the job. + + **Parameters** + + * **timeout** (`Optional`\[`float`]) – Number of seconds to wait for job. + * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. + + **Return type** + + `Any` + + **Returns** + + Runtime job result. + + **Raises** + + * **RuntimeJobFailureError** – If the job failed. + * **RuntimeJobMaxTimeoutError** – If the job does not complete within given timeout. + * **RuntimeInvalidStateError** – If the job was cancelled, and attempting to retrieve result. + + + ### running + + + Return whether the job is actively running. + + **Return type** + + `bool` + + + ### status + + + Return the status of the job. + + **Return type** + + `Literal`\[‘INITIALIZING’, ‘QUEUED’, ‘RUNNING’, ‘CANCELLED’, ‘DONE’, ‘ERROR’] + + **Returns** + + Status of this job. + + + ### stream\_results + + + (DEPRECATED) Start streaming job results. + + **Parameters** + + * **callback** (`Callable`) – + + Callback function to be invoked for any interim results and final result. The callback function will receive 2 positional parameters: + + > 1. Job ID + > 2. Job result. + + * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. + + **Raises** + + **RuntimeInvalidStateError** – If a callback function is already streaming results or if the job already finished. + + **Return type** + + `None` + + + ### update\_tags + + + Update the tags associated with this job. + + **Parameters** + + **new\_tags** (`List`\[`str`]) – New tags to assign to the job. + + **Return type** + + `List`\[`str`] + + **Returns** + + The new tags associated with this job. + + **Raises** + + **IBMApiError** – If an unexpected error occurred when communicating with the server or updating the job tags. + + + ### usage + + + Return job usage in seconds. + + **Return type** + + `float` + + + ### wait\_for\_final\_state + + + Poll for the job status from the API until the status is in a final state. + + **Parameters** + + **timeout** (`Optional`\[`float`]) – Seconds to wait for the job. If `None`, wait indefinitely. + + **Raises** + + **RuntimeJobTimeoutError** – If the job does not complete within given timeout. + + **Return type** + + `None` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Sampler.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Sampler.mdx new file mode 100644 index 00000000000..9c08360a745 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Sampler.mdx @@ -0,0 +1,14 @@ +--- +title: Sampler +description: API reference for qiskit_ibm_runtime.Sampler +in_page_toc_min_heading_level: 1 +python_api_type: attribute +python_api_name: qiskit_ibm_runtime.Sampler +--- + +# Sampler + + + alias of [`SamplerV2`](qiskit_ibm_runtime.SamplerV2 "qiskit_ibm_runtime.sampler.SamplerV2") + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.SamplerV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.SamplerV2.mdx new file mode 100644 index 00000000000..e906e9e6537 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.SamplerV2.mdx @@ -0,0 +1,95 @@ +--- +title: SamplerV2 +description: API reference for qiskit_ibm_runtime.SamplerV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.SamplerV2 +--- + +# SamplerV2 + + + Class for interacting with Qiskit Runtime Sampler primitive service. + + This class supports version 2 of the Sampler interface, which uses different input and output formats than version 1. + + Qiskit Runtime Sampler primitive returns the sampled result according to the specified output type. For example, it returns a bitstring for each shot if measurement level 2 (bits) is requested. + + The [`run()`](#qiskit_ibm_runtime.SamplerV2.run "qiskit_ibm_runtime.SamplerV2.run") method can be used to submit circuits and parameters to the Sampler primitive. + + Initializes the Sampler primitive. + + **Parameters** + + * **mode** (`Union`\[[`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "(in Qiskit v1.2)"), [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)"), [`Session`](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.session.Session"), [`Batch`](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.batch.Batch"), `str`, `None`]) – + + The execution mode used to make the primitive query. It can be: + + * A `Backend` if you are using job mode. + * A [`Session`](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.Session") if you are using session execution mode. + * A [`Batch`](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.Batch") if you are using batch execution mode. + + Refer to the [Qiskit Runtime documentation](/guides/execution-modes). for more information about the `Execution modes`. + + * **options** (`Union`\[`Dict`, [`SamplerOptions`](qiskit_ibm_runtime.options.SamplerOptions "qiskit_ibm_runtime.options.sampler_options.SamplerOptions"), `None`]) – Sampler options, see `SamplerOptions` for detailed description. + + **Raises** + + **NotImplementedError** – If “q-ctrl” channel strategy is used. + + ## Attributes + + ### mode + + + Return the execution mode used by this primitive. + + **Return type** + + Optional\[[Session](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.Session") | [Batch](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.Batch")] + + **Returns** + + Mode used by this primitive, or `None` if an execution mode is not used. + + + ### options + + + Return options + + **Return type** + + `TypeVar`(`OptionsT`, bound= `BaseOptions`) + + + ### version + + + + ## Methods + + ### run + + + Submit a request to the sampler primitive. + + **Parameters** + + * **pubs** (*Iterable\[SamplerPubLike]*) – An iterable of pub-like objects. For example, a list of circuits or tuples `(circuit, parameter_values)`. + * **shots** (*int | None*) – The total number of shots to sample for each sampler pub that does not specify its own shots. If `None`, the primitive’s default shots value will be used, which can vary by implementation. + + **Return type** + + [RuntimeJobV2](qiskit_ibm_runtime.RuntimeJobV2 "qiskit_ibm_runtime.RuntimeJobV2") + + **Returns** + + Submitted job. The result of the job is an instance of `qiskit.primitives.containers.PrimitiveResult`. + + **Raises** + + **ValueError** – Invalid arguments are given. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Session.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Session.mdx new file mode 100644 index 00000000000..dc5416a8ecb --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.Session.mdx @@ -0,0 +1,214 @@ +--- +title: Session +description: API reference for qiskit_ibm_runtime.Session +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.Session +--- + +# Session + + + Class for creating a Qiskit Runtime session. + + A Qiskit Runtime `session` allows you to group a collection of iterative calls to the quantum computer. A session is started when the first job within the session is started. Subsequent jobs within the session are prioritized by the scheduler. + + You can open a Qiskit Runtime session using this `Session` class and submit jobs to one or more primitives. + + For example: + + ```python + from qiskit.circuit import QuantumCircuit, QuantumRegister, ClassicalRegister + from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + from qiskit_ibm_runtime import Session, SamplerV2 as Sampler + + service = QiskitRuntimeService() + backend = service.least_busy(operational=True, simulator=False) + + # Bell Circuit + qr = QuantumRegister(2, name="qr") + cr = ClassicalRegister(2, name="cr") + qc = QuantumCircuit(qr, cr, name="bell") + qc.h(qr[0]) + qc.cx(qr[0], qr[1]) + qc.measure(qr, cr) + + pm = generate_preset_pass_manager(backend=backend, optimization_level=1) + isa_circuit = pm.run(qc) + + with Session(backend=backend) as session: + sampler = Sampler(session=session) + job = sampler.run([isa_circuit]) + pub_result = job.result()[0] + print(f"Sampler job ID: {job.job_id()}") + print(f"Counts: {pub_result.data.cr.get_counts()}") + ``` + + Session constructor. + + **Parameters** + + * **service** (`Optional`\[[`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")]) – (DEPRECATED) Optional instance of the `QiskitRuntimeService` class. If `None`, the service associated with the backend, if known, is used. Otherwise `QiskitRuntimeService()` is used to initialize your default saved account. + * **backend** (`Union`\[`str`, [`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "(in Qiskit v1.2)"), [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)"), `None`]) – Instance of `Backend` class or string name of backend. Note that passing a backend name is deprecated. + * **max\_time** (`Union`\[`int`, `str`, `None`]) – Maximum amount of time, a runtime session can be open before being forcibly closed. Can be specified as seconds (int) or a string like “2h 30m 40s”. This value must be less than the [system imposed maximum](/guides/max-execution-time). + + **Raises** + + **ValueError** – If an input value is invalid. + + ## Attributes + + ### service + + + Return service associated with this session. + + **Return type** + + [`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService") + + **Returns** + + [`qiskit_ibm_runtime.QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.QiskitRuntimeService") associated with this session. + + + ### session\_id + + + Return the session ID. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Session ID. None if the backend is a simulator. + + + ## Methods + + ### backend + + + Return backend for this session. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Backend for this session. None if unknown. + + + ### cancel + + + Cancel all pending jobs in a session. + + **Return type** + + `None` + + + ### close + + + Close the session so new jobs will no longer be accepted, but existing queued or running jobs will run to completion. The session will be terminated once there are no more pending jobs. + + **Return type** + + `None` + + + ### details + + + Return session details. + + **Return type** + + `Optional`\[`Dict`\[`str`, `Any`]] + + **Returns** + + A dictionary with the sessions details. + + * `id`: id of the session. + * `backend_name`: backend used for the session. + * `interactive_timeout`: The maximum idle time (in seconds) between jobs that is allowed to occur before the session is deactivated. + * `max_time`: Maximum allowed time (in seconds) for the session, subject to plan limits. + * `active_timeout`: The maximum time (in seconds) a session can stay active. + * `state`: State of the session - open, active, inactive, or closed. + * `accepting_jobs`: Whether or not the session is accepting jobs. + * `last_job_started`: Timestamp of when the last job in the session started. + * `last_job_completed`: Timestamp of when the last job in the session completed. + * `started_at`: Timestamp of when the session was started. + * `closed_at`: Timestamp of when the session was closed. + * `activated_at`: Timestamp of when the session state was changed to active. + * `mode`: Execution mode of the session. + * `usage_time`: The usage time, in seconds, of this Session or Batch. Usage is defined as the time a quantum system is committed to complete a job. + + + ### from\_id + + + Construct a Session object with a given session\_id + + **Parameters** + + * **session\_id** (`str`) – the id of the session to be created. This must be an already existing session id. + + * **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – + + instance of the `QiskitRuntimeService` class. + + **Raises:** + + IBMInputValueError: If given session\_id does not exist. + + **Return type** + + [`Session`](#qiskit_ibm_runtime.Session "qiskit_ibm_runtime.session.Session") + + **Returns** + + A new Session with the given `session_id` + + + ### status + + + Return current session status. + + **Return type** + + `Optional`\[`str`] + + **Returns** + + Session status as a string. + + * `Pending`: Session is created but not active. It will become active when the next job of this session is dequeued. + * `In progress, accepting new jobs`: session is active and accepting new jobs. + * `In progress, not accepting new jobs`: session is active and not accepting new jobs. + * `Closed`: max\_time expired or session was explicitly closed. + * `None`: status details are not available. + + + ### usage + + + Return session usage in seconds. + + Session usage is the time from when the first job starts until the session goes inactive, is closed, or when its last job completes, whichever happens last. + + Batch usage is the amount of time all jobs spend on the QPU. + + **Return type** + + `Optional`\[`float`] + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.Neat.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.Neat.mdx new file mode 100644 index 00000000000..42088766f7a --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.Neat.mdx @@ -0,0 +1,119 @@ +--- +title: Neat +description: API reference for qiskit_ibm_runtime.debug_tools.Neat +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.debug_tools.Neat +--- + +# Neat + + + A class to help understand the expected performance of estimator jobs. + + The “Noisy Estimator Analyzer Tool” (or “NEAT”) is a convenience tool that users of the `Estimator` primitive can employ to analyze and predict the performance of their queries. Its simulate method uses `qiskit-aer` to simulate the estimation task classically efficiently, either in ideal conditions or in the presence of noise. The simulations’ results can be compared with other simulation results or with primitive results results to draw custom figures of merit. + + **Parameters** + + * **backend** ([`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)")) – A backend. + * **noise\_model** (`Optional`\[[`NoiseModel`](https://qiskit.github.io/qiskit-aer/stubs/qiskit_aer.noise.NoiseModel.html#qiskit_aer.noise.NoiseModel "(in Qiskit Aer v0.15.0)")]) – A noise model for the operations of the given backend. If `None`, it defaults to the noise model generated by `NoiseModel.from_backend()`. + + ## Attributes + + ### noise\_model + + + The noise model used by this analyzer tool for the noisy simulations. + + **Return type** + + [`NoiseModel`](https://qiskit.github.io/qiskit-aer/stubs/qiskit_aer.noise.NoiseModel.html#qiskit_aer.noise.NoiseModel "(in Qiskit Aer v0.15.0)") + + + ## Methods + + ### backend + + + The backend used by this analyzer tool. + + **Return type** + + [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)") + + + ### ideal\_sim + + + Perform an ideal, noiseless simulation of the estimator task specified by `pubs`. + + This function uses `qiskit-aer`’s `Estimator` class to simulate the estimation task classically. + + + To ensure scalability, every circuit in `pubs` is required to be a Clifford circuit, so that it can be simulated efficiently regardless of its size. For estimation tasks that involve non-Clifford circuits, the recommended workflow consists of mapping the non-Clifford circuits to the nearest Clifford circuits using the `ConvertISAToClifford` transpiler pass, or equivalently, to use the Neat’s [`to_clifford()`](#qiskit_ibm_runtime.debug_tools.Neat.to_clifford "qiskit_ibm_runtime.debug_tools.Neat.to_clifford") convenience method. Alternatively, setting `cliffordize` to `True` ensures that the [`to_clifford()`](#qiskit_ibm_runtime.debug_tools.Neat.to_clifford "qiskit_ibm_runtime.debug_tools.Neat.to_clifford") method is applied automatically to the given `pubs` prior to the simulation. + + + **Parameters** + + * **pubs** (`Sequence`\[`Union`\[`EstimatorPub`, `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Real`]]]) – The PUBs specifying the estimation task of interest. + * **cliffordize** (`bool`) – Whether or not to automatically apply the `ConvertISAToClifford` transpiler pass to the given `pubs` before performing the simulations. + * **seed\_simulator** (`Optional`\[`int`]) – A seed for the simulator. + * **precision** (`float`) – The target precision for the estimates of each expectation value in the returned results. + + **Return type** + + [`NeatResult`](qiskit_ibm_runtime.debug_tools.NeatResult "qiskit_ibm_runtime.debug_tools.neat_results.NeatResult") + + **Returns** + + The results of the simulation. + + + ### noisy\_sim + + + Perform a noisy simulation of the estimator task specified by `pubs`. + + This function uses `qiskit-aer`’s `Estimator` class to simulate the estimation task classically. + + + To ensure scalability, every circuit in `pubs` is required to be a Clifford circuit, so that it can be simulated efficiently regardless of its size. For estimation tasks that involve non-Clifford circuits, the recommended workflow consists of mapping the non-Clifford circuits to the nearest Clifford circuits using the `ConvertISAToClifford` transpiler pass, or equivalently, to use the Neat’s [`to_clifford()`](#qiskit_ibm_runtime.debug_tools.Neat.to_clifford "qiskit_ibm_runtime.debug_tools.Neat.to_clifford") convenience method. Alternatively, setting `cliffordize` to `True` ensures that the [`to_clifford()`](#qiskit_ibm_runtime.debug_tools.Neat.to_clifford "qiskit_ibm_runtime.debug_tools.Neat.to_clifford") method is applied automatically to the given `pubs` prior to the simulation. + + + **Parameters** + + * **pubs** (`Sequence`\[`Union`\[`EstimatorPub`, `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Real`]]]) – The PUBs specifying the estimation task of interest. + * **cliffordize** (`bool`) – Whether or not to automatically apply the `ConvertISAToClifford` transpiler pass to the given `pubs` before performing the simulations. + * **seed\_simulator** (`Optional`\[`int`]) – A seed for the simulator. + * **precision** (`float`) – The target precision for the estimates of each expectation value in the returned results. + + **Return type** + + [`NeatResult`](qiskit_ibm_runtime.debug_tools.NeatResult "qiskit_ibm_runtime.debug_tools.neat_results.NeatResult") + + **Returns** + + The results of the simulation. + + + ### to\_clifford + + + Return the cliffordized version of the given `pubs`. + + This convenience method runs the `ConvertISAToClifford` transpiler pass on the PUBs’ circuits. + + **Parameters** + + **pubs** (`Sequence`\[`Union`\[`EstimatorPub`, `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Real`]]]) – The PUBs to turn into Clifford PUBs. + + **Return type** + + `list`\[`EstimatorPub`] + + **Returns** + + The Clifford PUBs. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx new file mode 100644 index 00000000000..544ead60137 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx @@ -0,0 +1,42 @@ +--- +title: NeatPubResult +description: API reference for qiskit_ibm_runtime.debug_tools.NeatPubResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.debug_tools.NeatPubResult +--- + +# NeatPubResult + + + A class to store the PUB results of `Neat`. + + It allows performing mathematical operations (`+`, `-`, `*`, `/`, `abs`, and `**`) with other objects of type `NeatPubResultLike` and with scalars. + + **Parameters** + + **vals** (`Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]) – The values in this `NeatPubResult`. + + ## Attributes + + ### vals + + + The values in this result. + + **Return type** + + [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v2.1)") + + + ## Methods + + ### \_\_mul\_\_ + + + **Return type** + + [`NeatPubResult`](#qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.neat_results.NeatPubResult") + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatResult.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatResult.mdx new file mode 100644 index 00000000000..c5f6bd9daec --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.debug_tools.NeatResult.mdx @@ -0,0 +1,36 @@ +--- +title: NeatResult +description: API reference for qiskit_ibm_runtime.debug_tools.NeatResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.debug_tools.NeatResult +--- + +# NeatResult + + + A container for multiple [`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.NeatPubResult") objects. + + **Parameters** + + **pub\_results** (`Iterable`\[[`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.neat_results.NeatPubResult")]) – An iterable of [`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.NeatPubResult") objects. + + ## Methods + + ### \_\_getitem\_\_ + + + **Return type** + + [`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.neat_results.NeatPubResult") + + + ### \_\_len\_\_ + + + **Return type** + + `int` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx new file mode 100644 index 00000000000..d225a962fb3 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx @@ -0,0 +1,141 @@ +--- +title: ExecutionSpan +description: API reference for qiskit_ibm_runtime.execution_span.ExecutionSpan +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpan +--- + +# ExecutionSpan + + + Abstract parent for classes that store an execution time span for a subset of job data. + + A pub is said to have dependence on an execution span if the corresponding execution includes data that forms any part of the pub’s results. + + Execution spans are equality checkable, and they implement a comparison operator based on the tuple `(start, stop)`, so can be sorted. + + **Parameters** + + * **start** (`datetime`) – The start time of the span, in UTC. + * **stop** (`datetime`) – The stop time of the span, in UTC. + + ## Attributes + + ### duration + + + The duration of this span, in seconds. + + **Return type** + + `float` + + + ### pub\_idxs + + + Which pubs, by index, have dependence on this execution span. + + **Return type** + + `list`\[`int`] + + + ### size + + + The total number of results with dependence on this execution span, across all pubs. + + This attribute is equivalent to the sum of the elements of all present [`mask()`](#qiskit_ibm_runtime.execution_span.ExecutionSpan.mask "qiskit_ibm_runtime.execution_span.ExecutionSpan.mask")s. For sampler results, it represents the total number of shots with dependence on this execution span. + + Combine this attribute with [`filter_by_pub()`](#qiskit_ibm_runtime.execution_span.ExecutionSpan.filter_by_pub "qiskit_ibm_runtime.execution_span.ExecutionSpan.filter_by_pub") to find the size of some particular pub: + + ```python + span.filter_by_pub(2).size + ``` + + **Return type** + + `int` + + + ### start + + + The start time of the span, in UTC. + + **Return type** + + `datetime` + + + ### stop + + + The stop time of the span, in UTC. + + **Return type** + + `datetime` + + + ## Methods + + ### contains\_pub + + + Return whether the pub with the given index has data with dependence on this span. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + bool + + **Returns** + + Whether there is dependence on this span. + + + ### filter\_by\_pub + + + Return a new span whose slices are filtered to the provided pub indices. + + For example, if this span contains slice information for pubs with indices 1, 3, 4 and `[1, 4]` is provided, then the span returned by this method will contain slice information for only those two indices, but be identical otherwise. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + [ExecutionSpan](#qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") + + **Returns** + + A new filtered span. + + + ### mask + + + Return an array-valued mask specifying which parts of a pub result depend on this span. + + **Parameters** + + **pub\_idx** (`int`) – The index of the pub to return a mask for. + + **Return type** + + [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v2.1)")\[`Any`, [`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[[`bool`](https://numpy.org/doc/stable/reference/arrays.scalars.html#numpy.bool "(in NumPy v2.1)")]] + + **Returns** + + An array with the same shape as the pub data. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx new file mode 100644 index 00000000000..f8c3cc4ad89 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx @@ -0,0 +1,114 @@ +--- +title: ExecutionSpans +description: API reference for qiskit_ibm_runtime.execution_span.ExecutionSpans +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans +--- + +# ExecutionSpans + + + A collection of timings for pub results. + + This class is a list-like containing [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")s, where each execution span represents a time window of data collection, and contains a reference to exactly which of the data were collected during the window. + + It is possible for distinct time windows to overlap. This is not because a QPU was performing multiple executions at once, but is instead an artifact of certain classical processing that may happen concurrently with quantum execution. The guarantee being made is that the referenced data definitely occurred in the reported execution span, but not necessarily that the limits of the time window are as tight as possible. + + ## Attributes + + ### duration + + + The total duration of this collection, in seconds. + + **Return type** + + `float` + + + ### pub\_idxs + + + Which pubs, by index, have dependence on one or more execution spans present. + + **Return type** + + `list`\[`int`] + + + ### start + + + The start time of the entire collection, in UTC. + + **Return type** + + `datetime` + + + ### stop + + + The stop time of the entire collection, in UTC. + + **Return type** + + `datetime` + + + ## Methods + + ### \_\_getitem\_\_ + + + **Return type** + + [ExecutionSpan](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") | ‘ExecutionSpans + + + ### \_\_len\_\_ + + + **Return type** + + `int` + + + ### filter\_by\_pub + + + Return a new set of spans where each one has been filtered to the specified pubs. + + See also :meth:\~.ExecutionSpan.filter\_by\_pub\`. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices to filter. + + **Return type** + + [ExecutionSpans](#qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans") + + + ### sort + + + Return the same execution spans, sorted. + + Sorting is done by the [`start`](qiskit_ibm_runtime.execution_span.ExecutionSpan#start "qiskit_ibm_runtime.execution_span.ExecutionSpan.start") timestamp of each execution span. + + **Parameters** + + **inplace** (`bool`) – Whether to sort this instance in place, or return a copy. + + **Return type** + + [`ExecutionSpans`](#qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.execution_spans.ExecutionSpans") + + **Returns** + + This instance if `inplace`, a new instance otherwise, sorted. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ShapeType.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ShapeType.mdx new file mode 100644 index 00000000000..7e0fd552068 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.ShapeType.mdx @@ -0,0 +1,14 @@ +--- +title: ShapeType +description: API reference for qiskit_ibm_runtime.execution_span.ShapeType +in_page_toc_min_heading_level: 1 +python_api_type: data +python_api_name: qiskit_ibm_runtime.execution_span.ShapeType +--- + +# ShapeType + + + alias of `Tuple`\[`int`, …] + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.SliceSpan.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.SliceSpan.mdx new file mode 100644 index 00000000000..61d5b35a550 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.execution_span.SliceSpan.mdx @@ -0,0 +1,128 @@ +--- +title: SliceSpan +description: API reference for qiskit_ibm_runtime.execution_span.SliceSpan +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.execution_span.SliceSpan +--- + +# SliceSpan + + + An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. + + This type of execution span references pub result data by assuming that it is a sliceable portion of the (row major) flattened data. Therefore, for each pub dependent on this span, the constructor accepts a single `slice` object, along with the corresponding shape of the data to be sliced. + + **Parameters** + + * **start** (`datetime`) – The start time of the span, in UTC. + * **stop** (`datetime`) – The stop time of the span, in UTC. + * **data\_slices** (`dict`\[`int`, `tuple`\[`Tuple`\[`int`, `...`], `slice`]]) – A map from pub indices to pairs `(shape_tuple, slice)`. + + ## Attributes + + ### duration + + + The duration of this span, in seconds. + + **Return type** + + `float` + + + ### pub\_idxs + + + **Return type** + + `list`\[`int`] + + + ### size + + + **Return type** + + `int` + + + ### start + + + The start time of the span, in UTC. + + **Return type** + + `datetime` + + + ### stop + + + The stop time of the span, in UTC. + + **Return type** + + `datetime` + + + ## Methods + + ### contains\_pub + + + Return whether the pub with the given index has data with dependence on this span. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + bool + + **Returns** + + Whether there is dependence on this span. + + + ### filter\_by\_pub + + + Return a new span whose slices are filtered to the provided pub indices. + + For example, if this span contains slice information for pubs with indices 1, 3, 4 and `[1, 4]` is provided, then the span returned by this method will contain slice information for only those two indices, but be identical otherwise. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + [SliceSpan](#qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan") + + **Returns** + + A new filtered span. + + + ### mask + + + Return an array-valued mask specifying which parts of a pub result depend on this span. + + **Parameters** + + **pub\_idx** (`int`) – The index of the pub to return a mask for. + + **Return type** + + [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v2.1)")\[`Any`, [`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[[`bool`](https://numpy.org/doc/stable/reference/arrays.scalars.html#numpy.bool "(in NumPy v2.1)")]] + + **Returns** + + An array with the same shape as the pub data. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx new file mode 100644 index 00000000000..c32045eb8bb --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx @@ -0,0 +1,454 @@ +--- +title: FakeAlgiers +description: API reference for qiskit_ibm_runtime.fake_provider.FakeAlgiers +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers +--- + +# FakeAlgiers + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeAlgiers.run "qiskit_ibm_runtime.fake_provider.FakeAlgiers.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx new file mode 100644 index 00000000000..8022c3e591d --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx @@ -0,0 +1,464 @@ +--- +title: FakeAlmadenV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 +--- + +# FakeAlmadenV2 + + + A fake Almaden V2 backend. + + ```python + 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ + 05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ + 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ + 15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.run "qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx new file mode 100644 index 00000000000..07110a2a402 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx @@ -0,0 +1,458 @@ +--- +title: FakeArmonkV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeArmonkV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 +--- + +# FakeArmonkV2 + + + A fake 1 qubit backend. + + ```python + 0 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeArmonkV2.run "qiskit_ibm_runtime.fake_provider.FakeArmonkV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx new file mode 100644 index 00000000000..c75f05f41ac --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeAthensV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeAthensV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 +--- + +# FakeAthensV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeAthensV2.run "qiskit_ibm_runtime.fake_provider.FakeAthensV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx new file mode 100644 index 00000000000..3ed88fdd8e1 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx @@ -0,0 +1,454 @@ +--- +title: FakeAuckland +description: API reference for qiskit_ibm_runtime.fake_provider.FakeAuckland +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland +--- + +# FakeAuckland + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeAuckland.run "qiskit_ibm_runtime.fake_provider.FakeAuckland.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx new file mode 100644 index 00000000000..ca168c10b43 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeBelemV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeBelemV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 +--- + +# FakeBelemV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeBelemV2.run "qiskit_ibm_runtime.fake_provider.FakeBelemV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx new file mode 100644 index 00000000000..5d81f536d7c --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx @@ -0,0 +1,464 @@ +--- +title: FakeBoeblingenV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 +--- + +# FakeBoeblingenV2 + + + A fake Boeblingen V2 backend. + + ```python + 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ + 05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ + 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ + 15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.run "qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx new file mode 100644 index 00000000000..5e43b960539 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeBogotaV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeBogotaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 +--- + +# FakeBogotaV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeBogotaV2.run "qiskit_ibm_runtime.fake_provider.FakeBogotaV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx new file mode 100644 index 00000000000..021c2847210 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx @@ -0,0 +1,454 @@ +--- +title: FakeBrisbane +description: API reference for qiskit_ibm_runtime.fake_provider.FakeBrisbane +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane +--- + +# FakeBrisbane + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeBrisbane.run "qiskit_ibm_runtime.fake_provider.FakeBrisbane.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx new file mode 100644 index 00000000000..336893a30e4 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeBrooklynV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 +--- + +# FakeBrooklynV2 + + + A fake Brooklyn V2 backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.run "qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx new file mode 100644 index 00000000000..6aa31b665f8 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx @@ -0,0 +1,460 @@ +--- +title: FakeBurlingtonV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 +--- + +# FakeBurlingtonV2 + + + A fake 5 qubit backend. + + ```python + 0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.run "qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx new file mode 100644 index 00000000000..b08db244ec1 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeCairoV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeCairoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 +--- + +# FakeCairoV2 + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeCairoV2.run "qiskit_ibm_runtime.fake_provider.FakeCairoV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx new file mode 100644 index 00000000000..5876f4f0c60 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx @@ -0,0 +1,466 @@ +--- +title: FakeCambridgeV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 +--- + +# FakeCambridgeV2 + + + A fake Cambridge backend. + + ```python + 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ + 05 06 + ↕ ↕ + 07 ↔ 08 ↔ 09 ↔ 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 ↔ 15 + ↕ ↕ ↕ + 16 17 18 + ↕ ↕ ↕ + 19 ↔ 20 ↔ 21 ↔ 22 ↔ 23 ↔ 24 ↔ 25 ↔ 26 ↔ 27 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.run "qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx new file mode 100644 index 00000000000..3200dccd376 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeCasablancaV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 +--- + +# FakeCasablancaV2 + + + A fake 7 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.run "qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx new file mode 100644 index 00000000000..8fdc03729c5 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx @@ -0,0 +1,454 @@ +--- +title: FakeCusco +description: API reference for qiskit_ibm_runtime.fake_provider.FakeCusco +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco +--- + +# FakeCusco + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeCusco.run "qiskit_ibm_runtime.fake_provider.FakeCusco.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx new file mode 100644 index 00000000000..42ceff241dc --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx @@ -0,0 +1,462 @@ +--- +title: FakeEssexV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeEssexV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 +--- + +# FakeEssexV2 + + + A fake 5 qubit backend. + + ```python + 0 ↔ 1 ↔ 2 + ↕ + 3 + ↕ + 4 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeEssexV2.run "qiskit_ibm_runtime.fake_provider.FakeEssexV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx new file mode 100644 index 00000000000..2cf022e9536 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx @@ -0,0 +1,461 @@ +--- +title: FakeFractionalBackend +description: API reference for qiskit_ibm_runtime.fake_provider.FakeFractionalBackend +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend +--- + +# FakeFractionalBackend + + + A fake 5 qubit backend with dynamic and fractional feature modeled based on FakeLima. + + This backend include following features. + + * Fractional gates (rx, rzx) in addition to the standard basis gates. + * Control flow operations (if\_else, while\_loop). + * Pulse calibrations (fractional gates don’t support calibration). + * Gate properties of all instructions. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.run "qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx new file mode 100644 index 00000000000..01fdfcce0fe --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx @@ -0,0 +1,454 @@ +--- +title: FakeGeneva +description: API reference for qiskit_ibm_runtime.fake_provider.FakeGeneva +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva +--- + +# FakeGeneva + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeGeneva.run "qiskit_ibm_runtime.fake_provider.FakeGeneva.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx new file mode 100644 index 00000000000..15c0e866261 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeGuadalupeV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 +--- + +# FakeGuadalupeV2 + + + A fake 16 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.run "qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx new file mode 100644 index 00000000000..ab96df41c4d --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeHanoiV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeHanoiV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 +--- + +# FakeHanoiV2 + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeHanoiV2.run "qiskit_ibm_runtime.fake_provider.FakeHanoiV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx new file mode 100644 index 00000000000..cb03b8dc162 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeJakartaV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeJakartaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 +--- + +# FakeJakartaV2 + + + A fake 7 qubit V2 backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeJakartaV2.run "qiskit_ibm_runtime.fake_provider.FakeJakartaV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx new file mode 100644 index 00000000000..70d39f63125 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx @@ -0,0 +1,464 @@ +--- +title: FakeJohannesburgV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 +--- + +# FakeJohannesburgV2 + + + A fake Johannesburg V2 backend. + + ```python + 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ + 05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ + 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ + 15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.run "qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx new file mode 100644 index 00000000000..3649e87c980 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx @@ -0,0 +1,454 @@ +--- +title: FakeKawasaki +description: API reference for qiskit_ibm_runtime.fake_provider.FakeKawasaki +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki +--- + +# FakeKawasaki + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeKawasaki.run "qiskit_ibm_runtime.fake_provider.FakeKawasaki.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx new file mode 100644 index 00000000000..bb01b7c20e9 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeKolkataV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeKolkataV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 +--- + +# FakeKolkataV2 + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeKolkataV2.run "qiskit_ibm_runtime.fake_provider.FakeKolkataV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx new file mode 100644 index 00000000000..8dc985d2eab --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx @@ -0,0 +1,454 @@ +--- +title: FakeKyiv +description: API reference for qiskit_ibm_runtime.fake_provider.FakeKyiv +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv +--- + +# FakeKyiv + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeKyiv.run "qiskit_ibm_runtime.fake_provider.FakeKyiv.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx new file mode 100644 index 00000000000..b8f745b7c6c --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx @@ -0,0 +1,454 @@ +--- +title: FakeKyoto +description: API reference for qiskit_ibm_runtime.fake_provider.FakeKyoto +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto +--- + +# FakeKyoto + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeKyoto.run "qiskit_ibm_runtime.fake_provider.FakeKyoto.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx new file mode 100644 index 00000000000..785308c0508 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeLagosV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeLagosV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 +--- + +# FakeLagosV2 + + + A fake 7 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeLagosV2.run "qiskit_ibm_runtime.fake_provider.FakeLagosV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx new file mode 100644 index 00000000000..2d0b2179389 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeLimaV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeLimaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 +--- + +# FakeLimaV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeLimaV2.run "qiskit_ibm_runtime.fake_provider.FakeLimaV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx new file mode 100644 index 00000000000..c8265710a69 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx @@ -0,0 +1,462 @@ +--- +title: FakeLondonV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeLondonV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 +--- + +# FakeLondonV2 + + + A fake 5 qubit backend. + + ```python + 0 ↔ 1 ↔ 2 + ↕ + 3 + ↕ + 4 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeLondonV2.run "qiskit_ibm_runtime.fake_provider.FakeLondonV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx new file mode 100644 index 00000000000..566e2f5a7d9 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeManhattanV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeManhattanV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 +--- + +# FakeManhattanV2 + + + A fake Manhattan backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeManhattanV2.run "qiskit_ibm_runtime.fake_provider.FakeManhattanV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx new file mode 100644 index 00000000000..d42d71fb2b6 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeManilaV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeManilaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 +--- + +# FakeManilaV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeManilaV2.run "qiskit_ibm_runtime.fake_provider.FakeManilaV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx new file mode 100644 index 00000000000..f987ea5b87a --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeMelbourneV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 +--- + +# FakeMelbourneV2 + + + A fake 14 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.run "qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx new file mode 100644 index 00000000000..124e32c77b5 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeMontrealV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeMontrealV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 +--- + +# FakeMontrealV2 + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeMontrealV2.run "qiskit_ibm_runtime.fake_provider.FakeMontrealV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx new file mode 100644 index 00000000000..f141e5ee473 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeMumbaiV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 +--- + +# FakeMumbaiV2 + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.run "qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx new file mode 100644 index 00000000000..ca7c9f1ead7 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeNairobiV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeNairobiV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 +--- + +# FakeNairobiV2 + + + A fake 7 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeNairobiV2.run "qiskit_ibm_runtime.fake_provider.FakeNairobiV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx new file mode 100644 index 00000000000..4d2340a7295 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx @@ -0,0 +1,454 @@ +--- +title: FakeOsaka +description: API reference for qiskit_ibm_runtime.fake_provider.FakeOsaka +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka +--- + +# FakeOsaka + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeOsaka.run "qiskit_ibm_runtime.fake_provider.FakeOsaka.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx new file mode 100644 index 00000000000..5a00c34d949 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx @@ -0,0 +1,454 @@ +--- +title: FakeOslo +description: API reference for qiskit_ibm_runtime.fake_provider.FakeOslo +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo +--- + +# FakeOslo + + + A fake 7 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeOslo.run "qiskit_ibm_runtime.fake_provider.FakeOslo.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx new file mode 100644 index 00000000000..660dd42ebef --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx @@ -0,0 +1,460 @@ +--- +title: FakeOurenseV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeOurenseV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 +--- + +# FakeOurenseV2 + + + A fake 5 qubit backend. + + ```python + 0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeOurenseV2.run "qiskit_ibm_runtime.fake_provider.FakeOurenseV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx new file mode 100644 index 00000000000..8071be20e3d --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx @@ -0,0 +1,466 @@ +--- +title: FakeParisV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeParisV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 +--- + +# FakeParisV2 + + + A fake Paris backend. + + ```python + 06 17 + ↕ ↕ + 00 ↔ 01 ↔ 04 ↔ 07 ↔ 10 ↔ 12 ↔ 15 ↔ 18 ↔ 20 ↔ 23 + ↕ ↕ ↕ + 02 13 24 + ↕ ↕ ↕ + 03 ↔ 05 ↔ 08 ↔ 11 ↔ 14 ↔ 16 ↔ 19 ↔ 22 ↔ 25 ↔ 26 + ↕ ↕ + 09 20 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeParisV2.run "qiskit_ibm_runtime.fake_provider.FakeParisV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx new file mode 100644 index 00000000000..0bee3fd7398 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx @@ -0,0 +1,454 @@ +--- +title: FakePeekskill +description: API reference for qiskit_ibm_runtime.fake_provider.FakePeekskill +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill +--- + +# FakePeekskill + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakePeekskill.run "qiskit_ibm_runtime.fake_provider.FakePeekskill.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePerth.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePerth.mdx new file mode 100644 index 00000000000..2c3b233bffd --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePerth.mdx @@ -0,0 +1,454 @@ +--- +title: FakePerth +description: API reference for qiskit_ibm_runtime.fake_provider.FakePerth +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth +--- + +# FakePerth + + + A fake 7 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakePerth.run "qiskit_ibm_runtime.fake_provider.FakePerth.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx new file mode 100644 index 00000000000..01a4f6c35ab --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakePoughkeepsieV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 +--- + +# FakePoughkeepsieV2 + + + A fake Poughkeepsie backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.run "qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePrague.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePrague.mdx new file mode 100644 index 00000000000..bed93f13811 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakePrague.mdx @@ -0,0 +1,454 @@ +--- +title: FakePrague +description: API reference for qiskit_ibm_runtime.fake_provider.FakePrague +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague +--- + +# FakePrague + + + A fake 33 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakePrague.run "qiskit_ibm_runtime.fake_provider.FakePrague.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx new file mode 100644 index 00000000000..771050045a2 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx @@ -0,0 +1,38 @@ +--- +title: FakeProviderForBackendV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2 +--- + +# FakeProviderForBackendV2 + + + Fake provider containing fake V2 backends. + + Only filtering backends by name is implemented. This class contains all fake V2 backends available in the [`qiskit_ibm_runtime.fake_provider`](fake_provider#module-qiskit_ibm_runtime.fake_provider "qiskit_ibm_runtime.fake_provider"). + + ## Methods + + ### backend + + + Filter backends in provider by name. + + **Return type** + + `FakeBackendV2` + + + ### backends + + + Return all backends accessible via this account. + + **Return type** + + `List`\[`FakeBackendV2`] + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx new file mode 100644 index 00000000000..0dd6397beb6 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx @@ -0,0 +1,454 @@ +--- +title: FakeQuebec +description: API reference for qiskit_ibm_runtime.fake_provider.FakeQuebec +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec +--- + +# FakeQuebec + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeQuebec.run "qiskit_ibm_runtime.fake_provider.FakeQuebec.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx new file mode 100644 index 00000000000..8226331957a --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeQuitoV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeQuitoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 +--- + +# FakeQuitoV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeQuitoV2.run "qiskit_ibm_runtime.fake_provider.FakeQuitoV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx new file mode 100644 index 00000000000..be2b9df06a3 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeRochesterV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeRochesterV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 +--- + +# FakeRochesterV2 + + + A fake Rochester backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeRochesterV2.run "qiskit_ibm_runtime.fake_provider.FakeRochesterV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx new file mode 100644 index 00000000000..4ce5ef12271 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeRomeV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeRomeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 +--- + +# FakeRomeV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeRomeV2.run "qiskit_ibm_runtime.fake_provider.FakeRomeV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx new file mode 100644 index 00000000000..e084bbea270 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeSantiagoV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 +--- + +# FakeSantiagoV2 + + + A fake Santiago backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.run "qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx new file mode 100644 index 00000000000..7f6bb665588 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx @@ -0,0 +1,454 @@ +--- +title: FakeSherbrooke +description: API reference for qiskit_ibm_runtime.fake_provider.FakeSherbrooke +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke +--- + +# FakeSherbrooke + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeSherbrooke.run "qiskit_ibm_runtime.fake_provider.FakeSherbrooke.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx new file mode 100644 index 00000000000..f62977bc9c1 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx @@ -0,0 +1,464 @@ +--- +title: FakeSingaporeV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 +--- + +# FakeSingaporeV2 + + + A fake Singapore backend. + + ```python + 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ + 05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ + 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ + 15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.run "qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx new file mode 100644 index 00000000000..8c1f6dd4ebb --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeSydneyV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeSydneyV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 +--- + +# FakeSydneyV2 + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeSydneyV2.run "qiskit_ibm_runtime.fake_provider.FakeSydneyV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx new file mode 100644 index 00000000000..20b0538a6f9 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx @@ -0,0 +1,454 @@ +--- +title: FakeTorino +description: API reference for qiskit_ibm_runtime.fake_provider.FakeTorino +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino +--- + +# FakeTorino + + + A fake 133 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeTorino.run "qiskit_ibm_runtime.fake_provider.FakeTorino.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx new file mode 100644 index 00000000000..68a5a650a3e --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeTorontoV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeTorontoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 +--- + +# FakeTorontoV2 + + + A fake 27 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeTorontoV2.run "qiskit_ibm_runtime.fake_provider.FakeTorontoV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx new file mode 100644 index 00000000000..8a388446ee1 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeValenciaV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeValenciaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 +--- + +# FakeValenciaV2 + + + A fake 5 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeValenciaV2.run "qiskit_ibm_runtime.fake_provider.FakeValenciaV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx new file mode 100644 index 00000000000..030237b25f1 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx @@ -0,0 +1,460 @@ +--- +title: FakeVigoV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeVigoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 +--- + +# FakeVigoV2 + + + A fake 5 qubit backend. + + ```python + 0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeVigoV2.run "qiskit_ibm_runtime.fake_provider.FakeVigoV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx new file mode 100644 index 00000000000..8a6959ca804 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx @@ -0,0 +1,454 @@ +--- +title: FakeWashingtonV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 +--- + +# FakeWashingtonV2 + + + A fake 127 qubit backend. + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.run "qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx new file mode 100644 index 00000000000..ca7d472bd98 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx @@ -0,0 +1,462 @@ +--- +title: FakeYorktownV2 +description: API reference for qiskit_ibm_runtime.fake_provider.FakeYorktownV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 +--- + +# FakeYorktownV2 + + + A fake 5 qubit backend. + + ```python + 1 + / | + 0 - 2 - 3 + | / + 4 + ``` + + FakeBackendV2 initializer. + + ## Attributes + + ### backend\_name + + + + ### conf\_filename + + + + ### coupling\_map + + + Return the [`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)") object + + + ### defs\_filename + + + + ### dirname + + + + ### dt + + + Return the system time resolution of input signals + + This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `Optional`\[`float`] + + **Returns** + + The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + ### dtm + + + Return the system time resolution of output signals + + **Return type** + + `float` + + **Returns** + + The output signal timestep in seconds. + + + ### instruction\_durations + + + Return the [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)") object. + + + ### instruction\_schedule\_map + + + Return the [`InstructionScheduleMap`](/api/qiskit/qiskit.pulse.InstructionScheduleMap "(in Qiskit v1.2)") for the instructions defined in this backend’s target. + + + ### instructions + + + A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + **Return type** + + `List`\[`Tuple`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)"), `Tuple`\[`int`]]] + + + ### max\_circuits + + + **Return type** + + `None` + + + ### meas\_map + + + Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + + **Return type** + + `List`\[`List`\[`int`]] + + **Returns** + + The grouping of measurements which are multiplexed + + + ### num\_qubits + + + Return the number of qubits the backend has. + + **Return type** + + `int` + + + ### operation\_names + + + A list of instruction names that the backend supports. + + **Return type** + + `List`\[`str`] + + + ### operations + + + A list of [`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)") instances that the backend supports. + + **Return type** + + `List`\[[`Instruction`](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")] + + + ### options + + + Return the options for the backend + + The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit_ibm_runtime.fake_provider.FakeYorktownV2.run "qiskit_ibm_runtime.fake_provider.FakeYorktownV2.run") method. + + + ### props\_filename + + + + ### provider + + + Return the backend Provider. + + **Returns** + + the Provider responsible for the backend. + + **Return type** + + Provider + + + ### target + + + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. + + **Return type** + + Target + + + ### version + + + + ### name + + + Name of the backend. + + + ### description + + + Optional human-readable description. + + + ### online\_date + + + Date that the backend came online. + + + ### backend\_version + + + Version of the backend being provided. This is not the same as `BackendV2.version`, which is the version of the `Backend` abstract interface. + + + ## Methods + + ### acquire\_channel + + + Return the acquisition channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement acquisition line. + + **Return type** + + AcquireChannel + + + ### check\_faulty + + + Check if the input circuit uses faulty qubits or edges. + + **Parameters** + + **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – Circuit to check. + + **Raises** + + **ValueError** – If an instruction operating on a faulty qubit or edge is found. + + **Return type** + + `None` + + + ### configuration + + + Return the backend configuration. + + **Return type** + + `Union`\[`QasmBackendConfiguration`, `PulseBackendConfiguration`] + + + ### control\_channel + + + Return the secondary drive channel for the given qubit + + This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Parameters** + + **qubits** (`Iterable`\[`int`]) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + + **Returns** + + The multi qubit control line. + + **Return type** + + List\[ControlChannel] + + + ### defaults + + + Return the pulse defaults for the backend + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend defaults from the + * **file.** (*local*) + + **Return type** + + `PulseDefaults` + + **Returns** + + The backend pulse defaults or `None` if the backend does not support pulse. + + + ### drive\_channel + + + Return the drive channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit drive channel + + **Return type** + + DriveChannel + + + ### measure\_channel + + + Return the measure stimulus channel for the given qubit. + + This is required to be implemented if the backend supports Pulse scheduling. + + **Returns** + + The Qubit measurement stimulus line + + **Return type** + + MeasureChannel + + + ### properties + + + Return the backend properties + + **Parameters** + + * **refresh** (`bool`) – If `True`, re-retrieve the backend properties + * **file.** (*from the local*) + + **Return type** + + `BackendProperties` + + **Returns** + + The backend properties. + + + ### qubit\_properties + + + Return QubitProperties for a given qubit. + + If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + + **Parameters** + + **qubit** (`Union`\[`int`, `List`\[`int`]]) – The qubit to get the `QubitProperties` object for. This can be a single integer for 1 qubit or a list of qubits and a list of `QubitProperties` objects will be returned in the same order + + **Return type** + + `Union`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)"), `List`\[[`QubitProperties`](/api/qiskit/qiskit.providers.QubitProperties "(in Qiskit v1.2)")]] + + **Returns** + + The `QubitProperties` object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + + **Raises** + + **NotImplementedError** – if the backend doesn’t support querying the qubit properties + + + ### refresh + + + Update the data files from its real counterpart + + This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json + + **The new data files will persist through sessions so the files will stay updated unless they** + + are manually reverted locally or when qiskit-ibm-runtime is upgraded/reinstalled. + + **Parameters** + + **service** ([`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.qiskit_runtime_service.QiskitRuntimeService")) – A `QiskitRuntimeService` instance + + **Raises** + + * **ValueError** – if the provided service is a non-QiskitRuntimeService instance. + * **Exception** – If the real target doesn’t exist or can’t be accessed + + **Return type** + + `None` + + + ### run + + + Run on the fake backend using a simulator. + + This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. + + If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using BasicSimulator without noise. + + Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + + **Parameters** + + * **run\_input** (*QuantumCircuit or Schedule or ScheduleBlock or list*) – An individual or a list of [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), [`ScheduleBlock`](/api/qiskit/qiskit.pulse.ScheduleBlock "(in Qiskit v1.2)"), or [`Schedule`](/api/qiskit/qiskit.pulse.Schedule "(in Qiskit v1.2)") objects to run on the backend. + * **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + + **Returns** + + The job object for the run + + **Return type** + + Job + + **Raises** + + **QiskitError** – If a pulse job is supplied and qiskit-aer is not installed. + + + ### set\_options + + + Set the options fields for the backend + + This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + + **Parameters** + + **fields** – The fields to update the options + + **Raises** + + **AttributeError** – If the field passed in is not part of the options + + + ### status + + + Return the backend status. + + **Return type** + + `BackendStatus` + + **Returns** + + The status of the backend. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx new file mode 100644 index 00000000000..108e9ee995f --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx @@ -0,0 +1,112 @@ +--- +title: NoiseLearner +description: API reference for qiskit_ibm_runtime.noise_learner.NoiseLearner +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.noise_learner.NoiseLearner +--- + +# NoiseLearner + + + Class for executing noise learning experiments. + + + Currently, the [`NoiseLearner`](#qiskit_ibm_runtime.noise_learner.NoiseLearner "qiskit_ibm_runtime.noise_learner.NoiseLearner") is released an experimental feature. As such, it is subject to change without notification and its stability is not guaranteed. + + + The noise learner class allows characterizing the noise processes affecting the gates in one or more circuits of interest, based on the Pauli-Lindblad noise model described in \[1]. + + The [`run()`](#qiskit_ibm_runtime.noise_learner.NoiseLearner.run "qiskit_ibm_runtime.noise_learner.NoiseLearner.run") method allows runnig a noise learner job for a list of circuits. After the job is submitted, the gates are collected into independent layers, and subsequently the resulting layers are are characterized individually. + + The way in which the gates are collected into layers depends on the twirling `strategy` specified in the given `options` (see `NoiseLearnerOptions` for more details). Note that all strategies obey barriers. For example, if you have three ISA entangling layers of interest, consider putting them into one circuit separated by barriers acting on the qubits you wish to twirl, and select `strategy="active-circuit"`. + + The following snippet shows an example where the noise learner is used to characterized the layers of two GHZ circuits. + + ```python + from qiskit.circuit import QuantumCircuit + from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + from qiskit_ibm_runtime import QiskitRuntimeService + from qiskit_ibm_runtime.noise_learner import NoiseLearner + from qiskit_ibm_runtime.options import NoiseLearnerOptions + + service = QiskitRuntimeService() + backend = service.least_busy(operational=True, simulator=False) + + # a circuit returning a two-qubit GHZ state + ghz = QuantumCircuit(2) + ghz.h(0) + ghz.cx(0, 1) + + # another circuit returning a two-qubit GHZ state + another_ghz = QuantumCircuit(3) + another_ghz.h(0) + another_ghz.cx(0, 1) + another_ghz.cx(1, 2) + another_ghz.cx(0, 1) + + pm = generate_preset_pass_manager(backend=backend, optimization_level=1) + circuits = pm.run([ghz, another_ghz]) + + # set the options + options = NoiseLearnerOptions() + options.layer_pair_depths = [0, 1, 10] + + # run the noise learner job + learner = NoiseLearner(backend, options) + job = learner.run(circuits) + ``` + + **Parameters** + + * **mode** (`Union`\[[`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)"), [`Session`](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.session.Session"), [`Batch`](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.batch.Batch"), `None`]) – + + The execution mode used to make the primitive query. It can be: + + * A `Backend` if you are using job mode. + * A `Session` if you are using session execution mode. + * A `Batch` if you are using batch execution mode. + + Refer to the [Qiskit Runtime documentation](/guides/execution-modes) for more information about the execution modes. + + * **options** (`Union`\[`Dict`, [`NoiseLearnerOptions`](qiskit_ibm_runtime.options.NoiseLearnerOptions "qiskit_ibm_runtime.options.noise_learner_options.NoiseLearnerOptions"), [`EstimatorOptions`](qiskit_ibm_runtime.options.EstimatorOptions "qiskit_ibm_runtime.options.estimator_options.EstimatorOptions"), `None`]) – `NoiseLearnerOptions`. Alternatively, `EstimatorOptions` can be provided for convenience, in which case the estimator options get reformatted into noise learner options and all the irrelevant fields are ignored. + + **References** + + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + + ## Attributes + + ### options + + + The options in this noise learner. + + **Return type** + + [`NoiseLearnerOptions`](qiskit_ibm_runtime.options.NoiseLearnerOptions "qiskit_ibm_runtime.options.noise_learner_options.NoiseLearnerOptions") + + + ## Methods + + ### run + + + Submit a request to the noise learner program. + + This function breaks the given list of circuits into a list of unique layers, following the strategy set by the `twirling_strategy` field specified in the `options` (see `NoiseLearnerOptions` for more details) and sorting them based on the number of times they occur in the various circuits. Then, it runs the noise learning experiment for as many layers as specified by the `max_layers_to_learn` field in the `options`, prioritizing layers that occurr more frequently. + + **Parameters** + + **circuits** (`Iterable`\[`Union`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `EstimatorPub`, `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]]], `Tuple`\[[`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)"), `Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)"), [`SparsePauliOp`](/api/qiskit/qiskit.quantum_info.SparsePauliOp "(in Qiskit v1.2)"), `Mapping`\[`Union`\[`str`, [`Pauli`](/api/qiskit/qiskit.quantum_info.Pauli "(in Qiskit v1.2)")], `float`], `_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]], `Mapping`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`, `Tuple`\[`Union`\[[`Parameter`](/api/qiskit/qiskit.circuit.Parameter "(in Qiskit v1.2)"), `str`], `...`]], `Union`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]], `_NestedSequence`\[`_SupportsArray`\[[`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`Any`]]], `bool`, `int`, `float`, `complex`, `str`, `bytes`, `_NestedSequence`\[`Union`\[`bool`, `int`, `float`, `complex`, `str`, `bytes`]]]], `Real`]]]) – An iterable of circuits to run the noise learner program for. Alternatively, estimator pub-like (primitive unified bloc) objects can be specified, such as tuples `(circuit, observables)` or `(circuit, observables, parameter_values)`. In this case, the pub-like objects are converted to a list of circuits, and all the other fields (such as `observables` and `parameter_values`) are ignored. + + **Return type** + + [`RuntimeJobV2`](qiskit_ibm_runtime.RuntimeJobV2 "qiskit_ibm_runtime.runtime_job_v2.RuntimeJobV2") + + **Returns** + + The submitted job. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx new file mode 100644 index 00000000000..7d027ba33ac --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx @@ -0,0 +1,64 @@ +--- +title: DynamicalDecouplingOptions +description: API reference for qiskit_ibm_runtime.options.DynamicalDecouplingOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.DynamicalDecouplingOptions +--- + +# DynamicalDecouplingOptions + + + Options for dynamical decoupling (DD). + + ## Attributes + + ### enable + + + Whether to enable DD as specified by the other options in this class. + + Default: False. + + + ### extra\_slack\_distribution + + + Where to put extra timing delays due to rounding issues. Rounding issues arise because the discrete time step `dt` of the system cannot be divided. This option takes following values. + + Default: “middle”. + + * `"middle"`: Put the extra slack to the interval at the middle of the sequence. + + * **`"edges"`: Divide the extra slack as evenly as possible into intervals at** + + beginning and end of the sequence. + + + ### scheduling\_method + + + Whether to schedule gates as soon as (“asap”) or as late as (“alap”) possible. + + Default: “alap”. + + + ### sequence\_type + + + Which dynamical decoupling sequence to use. + + Default: “XX”. + + * `"XX"`: use the sequence `tau/2 - (+X) - tau - (+X) - tau/2` + + * `"XpXm"`: use the sequence `tau/2 - (+X) - tau - (-X) - tau/2` + + * **`"XY4"`:use the sequence** + + `tau/2 - (+X) - tau - (+Y) - tau (-X) - tau - (-Y) - tau/2` + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EnvironmentOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EnvironmentOptions.mdx new file mode 100644 index 00000000000..91d916b9e7c --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EnvironmentOptions.mdx @@ -0,0 +1,51 @@ +--- +title: EnvironmentOptions +description: API reference for qiskit_ibm_runtime.options.EnvironmentOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.EnvironmentOptions +--- + +# EnvironmentOptions + + + Options related to the execution environment. + + ## Attributes + + ### callback + + + Callback function to be invoked for any interim results and final result. The callback function will receive 2 positional parameters: + + > 1. Job ID + > 2. Job result. + + Default: `None`. + + + ### job\_tags + + + Tags to be assigned to the job. The tags can subsequently be used as a filter in the `qiskit_ibm_runtime.qiskit_runtime_service.jobs()` function call. + + Default: `None`. + + + ### log\_level + + + logging level to set in the execution environment. The valid log levels are: `DEBUG`, `INFO`, `WARNING`, `ERROR`, and `CRITICAL`. + + Default: `WARNING`. + + + ### private + + + Boolean value for marking jobs as private. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EstimatorOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EstimatorOptions.mdx new file mode 100644 index 00000000000..8d56e9ab5bd --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.EstimatorOptions.mdx @@ -0,0 +1,131 @@ +--- +title: EstimatorOptions +description: API reference for qiskit_ibm_runtime.options.EstimatorOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.EstimatorOptions +--- + +# EstimatorOptions + + + Options for V2 Estimator. + + ## Attributes + + ### default\_precision + + + The default precision to use for any PUB or `run()` call that does not specify one. Each Estimator PUB can specify its own precision. If the `run()` method is given a precision, then that value is used for all PUBs in the `run()` call that do not specify their own. + + Default: 0.015625 (1 / sqrt(4096)). + + + ### default\_shots + + + The total number of shots to use per circuit per configuration. + + + If set, this value overrides [`default_precision`](#qiskit_ibm_runtime.options.EstimatorOptions.default_precision "qiskit_ibm_runtime.options.EstimatorOptions.default_precision"). + + + A configuration is a combination of a specific parameter value binding set and a physical measurement basis. A physical measurement basis groups together some collection of qubit-wise commuting observables for some specific circuit/parameter value set to create a single measurement with basis rotations that is inserted into hardware executions. + + If twirling is enabled, the value of this option will be divided over circuit randomizations, with a smaller number of shots per randomization. See the [`twirling`](#qiskit_ibm_runtime.options.EstimatorOptions.twirling "qiskit_ibm_runtime.options.EstimatorOptions.twirling") options. + + Default: `None`. + + + ### dynamical\_decoupling + + + Suboptions for dynamical decoupling. See [`DynamicalDecouplingOptions`](qiskit_ibm_runtime.options.DynamicalDecouplingOptions "qiskit_ibm_runtime.options.DynamicalDecouplingOptions") for all available options. + + + ### environment + + + + ### execution + + + Execution time options. See [`ExecutionOptionsV2`](qiskit_ibm_runtime.options.ExecutionOptionsV2 "qiskit_ibm_runtime.options.ExecutionOptionsV2") for all available options. + + + ### experimental + + + Experimental options. These options are subject to change without notification, and stability is not guaranteed. + + + ### max\_execution\_time + + + + ### optimization\_level + + + (DEPRECATED) How much optimization to perform on the circuits. Higher levels generate more optimized circuits, at the expense of longer processing times. + + * 0: no optimization + * 1: light optimization + + Default: 0. + + + ### resilience + + + Advanced resilience options to fine-tune the resilience strategy. See [`ResilienceOptionsV2`](qiskit_ibm_runtime.options.ResilienceOptionsV2 "qiskit_ibm_runtime.options.ResilienceOptionsV2") for all available options. + + + ### resilience\_level + + + How much resilience to build against errors. Higher levels generate more accurate results, at the expense of longer processing times. + + * 0: No mitigation. + + * 1: Minimal mitigation costs. Mitigate error associated with readout errors. + + * **2: Medium mitigation costs. Typically reduces bias in estimators but** + + is not guaranteed to be zero bias. + + Refer to the [Configure error mitigation for Qiskit Runtime](/guides/configure-error-mitigation) guide for more information about the error mitigation methods used at each level. + + Default: 1. + + + ### seed\_estimator + + + Seed used to control sampling. + + Default: `None`. + + + ### simulator + + + + ### twirling + + + Pauli twirling options. See [`TwirlingOptions`](qiskit_ibm_runtime.options.TwirlingOptions "qiskit_ibm_runtime.options.TwirlingOptions") for all available options. + + + ## Methods + + ### update + + + Update the options. + + **Return type** + + `None` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx new file mode 100644 index 00000000000..752c6842d5b --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx @@ -0,0 +1,30 @@ +--- +title: ExecutionOptionsV2 +description: API reference for qiskit_ibm_runtime.options.ExecutionOptionsV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.ExecutionOptionsV2 +--- + +# ExecutionOptionsV2 + + + Execution options for V2 primitives. + + ## Attributes + + ### init\_qubits + + + Whether to reset the qubits to the ground state for each shot. Default is `True`. + + + ### rep\_delay + + + The repetition delay. This is the delay between a measurement and the subsequent quantum circuit. This is only supported on backends that have `backend.dynamic_reprate_enabled=True`. It must be from the range supplied by `backend.rep_delay_range`. Default is given by `backend.default_rep_delay`. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx new file mode 100644 index 00000000000..eaeefa355ea --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx @@ -0,0 +1,54 @@ +--- +title: LayerNoiseLearningOptions +description: API reference for qiskit_ibm_runtime.options.LayerNoiseLearningOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.LayerNoiseLearningOptions +--- + +# LayerNoiseLearningOptions + + + Options for learning layer noise. This is only used by V2 Estimator. + + + These options are only used when the resilience level or options specify a technique that requires layer noise learning. + + + ## Attributes + + ### layer\_pair\_depths + + + The circuit depths (measured in number of pairs) to use in learning experiments. Pairs are used as the unit because we exploit the order-2 nature of our entangling gates in the noise learning implementation. A value of `3` would correspond to 6 layers of the layer of interest, for example. + + Default: (0, 1, 2, 4, 16, 32). + + + ### max\_layers\_to\_learn + + + The max number of unique layers to learn. A `None` value indicates that there is no limit. If there are more unique layers present, then some layers will not be learned or mitigated. The learned layers are prioritized based on the number of times they occur in a set of run Estimator PUBs, and for equally occurring layers are further sorted by the number of two-qubit gates in the layer. + + Default: 4. + + + ### num\_randomizations + + + The number of random circuits to use per learning circuit configuration. A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, and nine required measurement bases, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization") each). + + Default: 32. + + + ### shots\_per\_randomization + + + The total number of shots to use per random learning circuit. A learning circuit is a random circuit at a specific learning depth with a specific measurement basis that is executed on hardware. + + Default: 128. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx new file mode 100644 index 00000000000..956f9d0c9ce --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx @@ -0,0 +1,38 @@ +--- +title: MeasureNoiseLearningOptions +description: API reference for qiskit_ibm_runtime.options.MeasureNoiseLearningOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.MeasureNoiseLearningOptions +--- + +# MeasureNoiseLearningOptions + + + Options for measurement noise learning. This is only used by V2 Estimator. + + + These options are only used when the resilience level or options specify a technique that requires measurement noise learning. + + + ## Attributes + + ### num\_randomizations + + + The number of random circuits to draw for the measurement learning experiment. + + Default: 32. + + + ### shots\_per\_randomization + + + The number of shots to use for the learning experiment per random circuit. If “auto”, the value will be chosen automatically based on the input PUBs. + + Default: “auto”. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx new file mode 100644 index 00000000000..6c35f2eabea --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx @@ -0,0 +1,106 @@ +--- +title: NoiseLearnerOptions +description: API reference for qiskit_ibm_runtime.options.NoiseLearnerOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions +--- + +# NoiseLearnerOptions + + + Options for [`NoiseLearner`](qiskit_ibm_runtime.noise_learner.NoiseLearner "qiskit_ibm_runtime.noise_learner.NoiseLearner"). + + ## Attributes + + ### environment + + + + ### experimental + + + Experimental options. + + These options are subject to change without notification, and stability is not guaranteed. + + + ### layer\_pair\_depths + + + The circuit depths (measured in number of pairs) to use in learning experiments. + + Pairs are used as the unit because we exploit the order-2 nature of our entangling gates in the noise learning implementation. A value of `3` would correspond to 6 layers of the layer of interest, for example. Default: (0, 1, 2, 4, 16, 32). + + + ### max\_execution\_time + + + + ### max\_layers\_to\_learn + + + The max number of unique layers to learn. + + A `None` value indicates that there is no limit. If there are more unique layers present, then some layers will not be learned or mitigated. The learned layers are prioritized based on the number of times they occur, and for equally occurring layers are further sorted by the number of two-qubit gates in the layer. Default: 4. + + + ### num\_randomizations + + + The number of random circuits to use per learning circuit configuration. + + A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, and nine required measurement bases, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization "qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization") each). Default: 32. + + + ### shots\_per\_randomization + + + The total number of shots to use per random learning circuit. + + A learning circuit is a random circuit at a specific learning depth with a specific measurement basis that is executed on hardware. Default: 128. + + + ### simulator + + + + ### twirling\_strategy + + + The twirling strategy in the identified layers of two-qubit twirled gates. + + The allowed values are: + + > * `"active"`: in each individual twirled layer, only the instruction qubits are twirled. + > + > * **`"active-circuit"`: in each individual twirled layer, the union of all instruction** + > + > qubits in the circuit are twirled. + > + > * **`"active-accum"`: in each individual twirled layer, the union of instructions qubits** + > + > in the circuit up to the current twirled layer are twirled. + > + > * `"all"`: in each individual twirled layer, all qubits in the input circuit are twirled. + + + Barriers and delay instructions are ignored when determining whether a qubit is active. + + + Default: “active-accum”. + + + ## Methods + + ### update + + + Update the options. + + **Return type** + + `None` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.PecOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.PecOptions.mdx new file mode 100644 index 00000000000..638891240ed --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.PecOptions.mdx @@ -0,0 +1,41 @@ +--- +title: PecOptions +description: API reference for qiskit_ibm_runtime.options.PecOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.PecOptions +--- + +# PecOptions + + + Probabalistic error cancellation mitigation options. This is only used by V2 Estimator. + + ## Attributes + + ### max\_overhead + + + The maximum circuit sampling overhead allowed, or `None` for no maximum. + + Default: 100. + + + ### noise\_gain + + + The amount by which to scale the noise, where: + + * A value of 0 corresponds to removing the full learned noise. + * A value of 1 corresponds to no removal of the learned noise. + * A value between 0 and 1 corresponds to partially removing the learned noise. + * A value greater than one corresponds to amplifying the learned noise. + + If “auto”, the value in the range `[0, 1]` will be chosen automatically for each input PUB based on the learned noise strength, `max_overhead`, and the depth of the PUB. + + Default: “auto”. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx new file mode 100644 index 00000000000..f8f7c85a424 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx @@ -0,0 +1,72 @@ +--- +title: ResilienceOptionsV2 +description: API reference for qiskit_ibm_runtime.options.ResilienceOptionsV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.ResilienceOptionsV2 +--- + +# ResilienceOptionsV2 + + + Resilience options for V2 Estimator. + + ## Attributes + + ### layer\_noise\_learning + + + Layer noise learning options. See [`LayerNoiseLearningOptions`](qiskit_ibm_runtime.options.LayerNoiseLearningOptions "qiskit_ibm_runtime.options.LayerNoiseLearningOptions") for all options. + + + ### layer\_noise\_model + + + A `NoiseLearnerResult` or a sequence of `LayerError` objects. If set, all the mitigation strategies that require noise data (e.g., PEC and PEA) skip the noise-learning stage, and instead gather the required information from `layer_noise_model`. Layers whose information is missing in `layer_noise_model` are treated as noiseless and their noise is not mitigated. + + + ### measure\_mitigation + + + Whether to enable measurement error mitigation method. If you enable measurement mitigation, you can fine-tune its noise learning by using [`measure_noise_learning`](#qiskit_ibm_runtime.options.ResilienceOptionsV2.measure_noise_learning "qiskit_ibm_runtime.options.ResilienceOptionsV2.measure_noise_learning"). See [`MeasureNoiseLearningOptions`](qiskit_ibm_runtime.options.MeasureNoiseLearningOptions "qiskit_ibm_runtime.options.MeasureNoiseLearningOptions") for all measurement mitigation noise learning options. + + Default: True. + + + ### measure\_noise\_learning + + + Additional measurement noise learning options. See [`MeasureNoiseLearningOptions`](qiskit_ibm_runtime.options.MeasureNoiseLearningOptions "qiskit_ibm_runtime.options.MeasureNoiseLearningOptions") for all options. + + + ### pec + + + Additional probabalistic error cancellation mitigation options. See [`PecOptions`](qiskit_ibm_runtime.options.PecOptions "qiskit_ibm_runtime.options.PecOptions") for all options. + + + ### pec\_mitigation + + + Whether to turn on Probabilistic Error Cancellation error mitigation method. If you enable PEC, you can fine-tune its options by using [`pec`](#qiskit_ibm_runtime.options.ResilienceOptionsV2.pec "qiskit_ibm_runtime.options.ResilienceOptionsV2.pec"). See [`PecOptions`](qiskit_ibm_runtime.options.PecOptions "qiskit_ibm_runtime.options.PecOptions") for additional PEC-related options. + + Default: False. + + + ### zne + + + Additional zero-noise extrapolation mitigation options. See [`ZneOptions`](qiskit_ibm_runtime.options.ZneOptions "qiskit_ibm_runtime.options.ZneOptions") for all options. + + + ### zne\_mitigation + + + Whether to turn on Zero-Noise Extrapolation error mitigation method. If you enable ZNE, you can fine-tune its options by using [`zne`](#qiskit_ibm_runtime.options.ResilienceOptionsV2.zne "qiskit_ibm_runtime.options.ResilienceOptionsV2.zne"). See [`ZneOptions`](qiskit_ibm_runtime.options.ZneOptions "qiskit_ibm_runtime.options.ZneOptions") for additional ZNE related options. + + Default: False. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx new file mode 100644 index 00000000000..38f13d7f87b --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx @@ -0,0 +1,46 @@ +--- +title: SamplerExecutionOptionsV2 +description: API reference for qiskit_ibm_runtime.options.SamplerExecutionOptionsV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.SamplerExecutionOptionsV2 +--- + +# SamplerExecutionOptionsV2 + + + Extension of [`ExecutionOptionsV2`](qiskit_ibm_runtime.options.ExecutionOptionsV2 "qiskit_ibm_runtime.options.ExecutionOptionsV2") for the sampler primitive. + + ## Attributes + + ### init\_qubits + + + Whether to reset the qubits to the ground state for each shot. Default is `True`. + + + ### meas\_type + + + How to process and return measurement results. + + This option sets the return type of all classical registers in all `SamplerPubResult`s. If a sampler pub with shape `pub_shape` has a circuit that contains a classical register with size `creg_size`, then the returned data associated with this register will have one of the following formats depending on the value of this option. + + * `"classified"`: A `BitArray` of shape `pub_shape` over `num_shots` with a number of bits equal to `creg_size`. + * `"kerneled"`: A complex NumPy array of shape `(*pub_shape, num_shots, creg_size)`, where each entry represents an IQ data point (resulting from kerneling the measurement trace) in arbitrary units. + * `"avg_kerneled"`: A complex NumPy array of shape `(*pub_shape, creg_size)`, where each entry represents an IQ data point (resulting from kerneling the measurement trace and averaging over shots) in arbitrary units. This option is equivalent to selecting `"kerneled"` and then averaging over the shots axis, but requires less data bandwidth. + + Default: “classified”. + + See [here](https://pubs.aip.org/aip/rsi/article/88/10/104703/836456) for a description of kerneling. + + + ### rep\_delay + + + The repetition delay. This is the delay between a measurement and the subsequent quantum circuit. This is only supported on backends that have `backend.dynamic_reprate_enabled=True`. It must be from the range supplied by `backend.rep_delay_range`. Default is given by `backend.default_rep_delay`. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerOptions.mdx new file mode 100644 index 00000000000..7b156e29866 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SamplerOptions.mdx @@ -0,0 +1,72 @@ +--- +title: SamplerOptions +description: API reference for qiskit_ibm_runtime.options.SamplerOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.SamplerOptions +--- + +# SamplerOptions + + + Options for V2 Sampler. + + ## Attributes + + ### default\_shots + + + The default number of shots to use if none are specified in the PUBs or in the run method. + + Default: 4096. + + + ### dynamical\_decoupling + + + Suboptions for dynamical decoupling. See [`DynamicalDecouplingOptions`](qiskit_ibm_runtime.options.DynamicalDecouplingOptions "qiskit_ibm_runtime.options.DynamicalDecouplingOptions") for all available options. + + + ### environment + + + + ### execution + + + Execution time options. See [`SamplerExecutionOptionsV2`](qiskit_ibm_runtime.options.SamplerExecutionOptionsV2 "qiskit_ibm_runtime.options.SamplerExecutionOptionsV2") for all available options. + + + ### experimental + + + Experimental options. + + + ### max\_execution\_time + + + + ### simulator + + + + ### twirling + + + Pauli twirling options. See [`TwirlingOptions`](qiskit_ibm_runtime.options.TwirlingOptions "qiskit_ibm_runtime.options.TwirlingOptions") for all available options. + + + ## Methods + + ### update + + + Update the options. + + **Return type** + + `None` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SimulatorOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SimulatorOptions.mdx new file mode 100644 index 00000000000..e6d6a917368 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.SimulatorOptions.mdx @@ -0,0 +1,70 @@ +--- +title: SimulatorOptions +description: API reference for qiskit_ibm_runtime.options.SimulatorOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.SimulatorOptions +--- + +# SimulatorOptions + + + Simulator options. + + For best practice in simulating a backend make sure to pass the basis gates and coupling map of that backend. + + ## Attributes + + ### basis\_gates + + + List of basis gate names to unroll to. For example, `['u1', 'u2', 'u3', 'cx']`. Unrolling is not done if not set. + + Default: all basis gates supported by the simulator. + + + ### coupling\_map + + + Directed coupling map to target in mapping. If the coupling map is symmetric, both directions need to be specified. Each entry in the list specifies a directed two-qubit interaction, e.g: `[[0, 1], [0, 3], [1, 2], [1, 5], [2, 5], [4, 1], [5, 3]]`. + + Default: `None`, which implies no connectivity constraints. + + + ### noise\_model + + + Noise model for the simulator. + + Default: `None`. + + + ### seed\_simulator + + + Random seed to control sampling. + + Default: `None`. + + + ## Methods + + ### set\_backend + + + Set backend for simulation. This method changes noise\_model, coupling\_map, basis\_gates according to given backend. + + **Parameters** + + **backend** (`Union`\[[`BackendV1`](/api/qiskit/qiskit.providers.BackendV1 "(in Qiskit v1.2)"), [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)")]) – backend to be set. + + **Raises** + + **MissingOptionalLibraryError** – if qiskit-aer is not found. + + **Return type** + + `None` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.TwirlingOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.TwirlingOptions.mdx new file mode 100644 index 00000000000..42be9a5ebeb --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.TwirlingOptions.mdx @@ -0,0 +1,81 @@ +--- +title: TwirlingOptions +description: API reference for qiskit_ibm_runtime.options.TwirlingOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.TwirlingOptions +--- + +# TwirlingOptions + + + Twirling options. + + ## Attributes + + ### enable\_gates + + + Whether to apply 2-qubit Clifford gate twirling. Default: False. + + + ### enable\_measure + + + Whether to enable twirling of measurements. + + Twirling will only be applied to those measurement registers not involved within a conditional logic. Default: True for Estimator, false for Sampler. + + + ### num\_randomizations + + + The number of random samples to use when twirling or peforming sampled mitigation. + + If `num_randomizations` is “auto”, for every pub executed `shots` times: + + > * If `shots_per_randomization` is also “auto”, `shots_per_randomization` is set first as described below, then `num_randomizations` is set as `ceil(shots/shots_per_randomization)`, where `ceil` is the ceiling function. + > * Otherwise, the value is set to `ceil(shots/shots_per_randomization)`. + > + > Default: “auto”. + + + The `shots` value specified in a PUB or in the `run()` method is considered part of the primitive execution interface and therefore is always obeyed. `default_shots`, on the other hand, is considered a Qiskit Runtime specific option. Therefore, the product of `num_randomizations` and `shots_per_randomization` takes precedence over `default_shots`. + + + + ### shots\_per\_randomization + + + The number of shots to run for each random sample. + + If “auto”, for every pub executed `shots` times: + + > * If `num_randomizations` is also “auto”, the value is set to `64` for PEC mitigation or to `max(64, ceil(shots / 32))` in all other cases, where `ceil` is the ceiling function. + > * Otherwise, the value is set to `ceil(shots/num_randomizations)`. + > + > Default: “auto”. + + + The `shots` value specified in a PUB or in the `run()` method is considered part of the primitive execution interface and therefore is always obeyed. `default_shots`, on the other hand, is considered a Qiskit Runtime specific option. Therefore, the product of `num_randomizations` and `shots_per_randomization` takes precedence over `default_shots`. + + + + ### strategy + + + Specify the strategy of twirling qubits in identified layers of 2-qubit twirled gates. + + Allowed values are: + + > * If `"active"` only the instruction qubits in each individual twirled layer will be twirled. + > * If `"active-circuit"` the union of all instruction qubits in the circuit will be twirled in each twirled layer. + > * If `"active-accum"` the union of instructions qubits in the circuit up to the current twirled layer will be twirled in each individual twirled layer. + > * If `"all"` all qubits in the input circuit will be twirled in each twirled layer. + > + > Default: “active-accum”. + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ZneOptions.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ZneOptions.mdx new file mode 100644 index 00000000000..70b47e566d2 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.options.ZneOptions.mdx @@ -0,0 +1,88 @@ +--- +title: ZneOptions +description: API reference for qiskit_ibm_runtime.options.ZneOptions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.options.ZneOptions +--- + +# ZneOptions + + + Zero noise extrapolation mitigation options. This is only used by the V2 Estimator. + + + Any V2 estimator is guaranteed to return data fields called `evs` and `stds` that report the desired expectation value estimates and errors, respectively. When ZNE options are enabled in the runtime estimator, additional data is returned. + + In particular, suppose an input pub has observable array shape `obs_shape` and parameter values shape `par_shape`, with corresponding pub shape `shape=np.broadcast_shapes(obs_shape, par_shape)`. Then the corresponding pub result will additionally contain: + + 1. **pub\_result.data.evs\_extrapolated and pub\_result.data.stds\_extrapolated,** + + both with shape `(*shape, num_extrapolators, num_evaluation_points)`, where `num_extrapolators` is the length of the list of `options.resilience.zne.extrapolators`, and `num_evaluation_points` is the length of the list `options.resilience.extrapolated_noise_factors`. These values provide evaluations of every extrapolator at every specified noise extrapolation value. + + 2. `pub_result.data.evs_noise_factors`, `pub_result.data.stds_noise_factors`, and `ensemble_stds_noise_factors` all have shape `(*shape, num_noise_factors)` where `num_noise_factors` is the length of `options.resilience.zne.noise_factors`. These values provide evaluations of the best-fit model at each of the noise amplifications. In the case of no twirling, both `*stds*` arrays will be equal, otherwise, `stds_noise_factors` is derived from the spread over twirling samples, whereas `ensemble_stds_noise_factors` assumes only shot noise and no drift. + + Technical note: for single observables with multiple basis terms it might turn out that multiple extrapolation methods are used in *the same* expectation value, for example, `XX` gets linearly extrapolated but `XY` gets exponentially extrapolated in the observable `{"XX": 0.5, "XY": 0.5}`. Let’s call this a *hetergeneous fit*. The data from (2) is evaluated from heterogeneous fits by selecting the best fit for every individual distinct term, whereas data from (1) is evaluated from forced homogenous fits, one for each provided extrapolator. If your work requires a nuanced distinction in this regard, we presently recommend that you use single-term observables in addition to your multi-term observables. + + + **Parameters** + + * **amplifier** – + + Which technique to use for amplifying noise. One of: + + * ”gate\_folding” (default) uses 2-qubit gate folding to amplify noise. If the noise factor requires amplifying only a subset of the gates, then these gates are chosen randomly. + + * ”gate\_folding\_front” uses 2-qubit gate folding to amplify noise. If the noise factor requires amplifying only a subset of the gates, then these gates are selected from the front of the topologically ordered DAG circuit. + + * ”gate\_folding\_back” uses 2-qubit gate folding to amplify noise. If the noise factor requires amplifying only a subset of the gates, then these gates are selected from the back of the topologically ordered DAG circuit. + + * ”pea” uses a technique called Probabilistic Error Amplification ([PEA](https://www.nature.com/articles/s41586-023-06096-3)) to amplify noise. + + When this option is selected, gate twirling will always be used whether or not it has been enabled in the options. + + In this technique, the twirled noise model of each each unique layer of entangling gates in your ISA circuits is learned beforehand, see [`LayerNoiseLearningOptions`](qiskit_ibm_runtime.options.LayerNoiseLearningOptions "qiskit_ibm_runtime.options.LayerNoiseLearningOptions") for relevant learning options. Once complete, your circuits are executed at each noise factor, where every entangling layer of your circuits is amplified by probabilistically injecting single-qubit noise proportional to the corresponding learned noise model. + + * **noise\_factors** – Noise factors to use for noise amplification. Default: `(1, 1.5, 2)` for PEA, and `(1, 3, 5)` otherwise. + + * **extrapolated\_noise\_factors** – Noise factors to evaluate the fit extrapolation models at. If unset, this will default to `[0, *noise_factors]`. This option does not affect execution or model fitting in any way, it only determines the points at which the `extrapolator`s are evaluated to be returned in the data fields called `evs_extrapolated` and `stds_extrapolated`. + + * **extrapolator** – + + Extrapolator(s) to try (in order) for extrapolating to zero noise. The available options are: + + > * `"exponential"`, which fits the data using an exponential decaying function defined as $f(x; A, au) = A e^{-x/ au}$, where $A = f(0; A, au)$ is the value at zero noise ($x=0$) and :math:\` au>0\` is a positive rate. + > * `"double_exponential"`, which uses a sum of two exponential as in Ref. 1. + > * `"polynomial_degree_(1 <= k <= 7)"`, which uses a polynomial function defined as $f(x; c_0, c_1, \ldots, c_k) = \sum_{i=0, k} c_i x^i$. + > * `"linear"`, which is equivalent to `"polynomial_degree_1"`. + > * `"fallback"`, which simply returns the raw data corresponding to the lowest noise factor (typically `1`) without performing any sort of extrapolation. + + If more than one extrapolator is specified, the `evs` and `stds` reported in the result’s data refer to the first one, while the extrapolated values (`evs_extrapolated` and `stds_extrapolated`) are sorted according to the order of the extrapolators provided. + + Default: `("exponential", "linear")`. + + **References** + + 1. Z. Cai, *Multi-exponential error extrapolation and combining error mitigation techniques for NISQ applications*, [npj Quantum Inf 7, 80 (2021)](https://www.nature.com/articles/s41534-021-00404-3) + + ## Attributes + + ### amplifier + + + + ### extrapolated\_noise\_factors + + + + ### extrapolator + + + + ### noise\_factors + + + + ## Methods + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx new file mode 100644 index 00000000000..c88e83e4424 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx @@ -0,0 +1,149 @@ +--- +title: ConvertISAToClifford +description: API reference for qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford +--- + +# ConvertISAToClifford + + + Convert the gates of an ISA circuit to Clifford gates. + + ISA circuits only contain Clifford gates from a restricted set or [`qiskit.circuit.library.RZGate`](/api/qiskit/qiskit.circuit.library.RZGate "(in Qiskit v1.2)")s by arbitrary angles. To convert them to Clifford circuits, this pass rounds the angle of every [`qiskit.circuit.library.RZGate`](/api/qiskit/qiskit.circuit.library.RZGate "(in Qiskit v1.2)") to the closest multiple of pi/2 (or to a random multiple of pi/2 if the angle is unspecified), while it skips every Clifford gate, measurement, and barrier. + + ```python + import numpy as np + + from qiskit.circuit import QuantumCircuit, Parameter + from qiskit.transpiler import PassManager + + from qiskit_ibm_runtime.transpiler.passes import ConvertISAToClifford + + # An ISA circuit ending with a Z rotation by pi/3 + qc = QuantumCircuit(2, 2) + qc.sx(0) + qc.rz(np.pi/2, 0) + qc.sx(0) + qc.barrier() + qc.cx(0, 1) + qc.rz(np.pi/3, 0) # non-Clifford Z rotation + qc.rz(Parameter("th"), 0) # Z rotation with unspecified angle + + # Turn into a Clifford circuit + pm = PassManager([ConvertISAToClifford()]) + clifford_qc = pm.run(qc) + ``` + + **Raises** + + **ValueError** – If the given circuit contains unsupported operations, such as non-ISA gates. + + ## Attributes + + ### is\_analysis\_pass + + + Check if the pass is an analysis pass. + + If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + ### is\_transformation\_pass + + + Check if the pass is a transformation pass. + + If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + + + ## Methods + + ### \_\_call\_\_ + + + Runs the pass on circuit. + + **Parameters** + + * **circuit** (*QuantumCircuit*) – The dag on which the pass is run. + * **property\_set** (*PropertySet | dict | None*) – Input/output property set. An analysis pass might change the property set in-place. + + **Return type** + + QuantumCircuit + + **Returns** + + If on transformation pass, the resulting QuantumCircuit. If analysis pass, the input circuit. + + + ### execute + + + Execute optimization task for input Qiskit IR. + + **Parameters** + + * **passmanager\_ir** (`Any`) – Qiskit IR to optimize. + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – State associated with workflow execution by the pass manager itself. + * **callback** (`Optional`\[`Callable`]) – A callback function which is caller per execution of optimization task. + + **Return type** + + `tuple`\[`Any`, [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")] + + **Returns** + + Optimized Qiskit IR and state of the workflow. + + + ### name + + + Name of the pass. + + **Return type** + + `str` + + + ### run + + + Run a pass on the DAGCircuit. This is implemented by the pass developer. + + **Parameters** + + **dag** ([`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")) – the dag on which the pass is run. + + **Raises** + + **NotImplementedError** – when this is left unimplemented for a pass. + + **Return type** + + [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)") + + + ### update\_status + + + Update workflow status. + + **Parameters** + + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – Pass manager state to update. + * **run\_state** (`RunState`) – Completion status of current task. + + **Return type** + + [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)") + + **Returns** + + Updated pass manager state. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx new file mode 100644 index 00000000000..0ebb38050d3 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx @@ -0,0 +1,127 @@ +--- +title: ConvertIdToDelay +description: API reference for qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay +--- + +# ConvertIdToDelay + + + Convert `qiskit.circuit.library.standard_gates.IGate` to a delay of the corresponding length. + + Convert [`qiskit.circuit.library.IGate`](/api/qiskit/qiskit.circuit.library.IGate "(in Qiskit v1.2)") to a Convert [`qiskit.circuit.Delay`](/api/qiskit/circuit#qiskit.circuit.Delay "(in Qiskit v1.2)"). + + **Parameters** + + * **duration** – Duration of the delay to replace the identity gate with. + * **gate** (`str`) – Single qubit gate to extract duration from. + + ## Attributes + + ### is\_analysis\_pass + + + Check if the pass is an analysis pass. + + If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + ### is\_transformation\_pass + + + Check if the pass is a transformation pass. + + If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + + + ## Methods + + ### \_\_call\_\_ + + + Runs the pass on circuit. + + **Parameters** + + * **circuit** (*QuantumCircuit*) – The dag on which the pass is run. + * **property\_set** (*PropertySet | dict | None*) – Input/output property set. An analysis pass might change the property set in-place. + + **Return type** + + QuantumCircuit + + **Returns** + + If on transformation pass, the resulting QuantumCircuit. If analysis pass, the input circuit. + + + ### execute + + + Execute optimization task for input Qiskit IR. + + **Parameters** + + * **passmanager\_ir** (`Any`) – Qiskit IR to optimize. + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – State associated with workflow execution by the pass manager itself. + * **callback** (`Optional`\[`Callable`]) – A callback function which is caller per execution of optimization task. + + **Return type** + + `tuple`\[`Any`, [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")] + + **Returns** + + Optimized Qiskit IR and state of the workflow. + + + ### name + + + Name of the pass. + + **Return type** + + `str` + + + ### run + + + Run a pass on the DAGCircuit. This is implemented by the pass developer. + + **Parameters** + + **dag** ([`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")) – the dag on which the pass is run. + + **Raises** + + **NotImplementedError** – when this is left unimplemented for a pass. + + **Return type** + + [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)") + + + ### update\_status + + + Update workflow status. + + **Parameters** + + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – Pass manager state to update. + * **run\_state** (`RunState`) – Completion status of current task. + + **Return type** + + [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)") + + **Returns** + + Updated pass manager state. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx new file mode 100644 index 00000000000..ec57aa6fff4 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx @@ -0,0 +1,142 @@ +--- +title: ALAPScheduleAnalysis +description: API reference for qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis +--- + +# ALAPScheduleAnalysis + + + Dynamic circuits as-late-as-possible (ALAP) scheduling analysis pass. + + This is a scheduler designed to work for the unique scheduling constraints of the dynamic circuits backends due to the limitations imposed by hardware. This is expected to evolve over time as the dynamic circuit backends also change. + + In its current form this is similar to Qiskit’s ALAP scheduler in which instructions start as late as possible. + + The primary differences are that: + + * **Resets and control-flow currently trigger the end of a “quantum block”. The period between the end** + + of the block and the next is *nondeterministic* ie., we do not know when the next block will begin (as we could be evaluating a classical function of nondeterministic length) and therefore the next block starts at a *relative* t=0. + + * During a measurement it is possible to apply gates in parallel on disjoint qubits. + + * Measurements and resets on disjoint qubits happen simultaneously and are part of the same block. + + Scheduler for dynamic circuit backends. + + **Parameters** + + * **durations** ([`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)")) – Durations of instructions to be used in scheduling. + * **block\_ordering\_callable** (`Optional`\[`Callable`\[\[[`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")], `Generator`\[[`DAGOpNode`](/api/qiskit/qiskit.dagcircuit.DAGOpNode "(in Qiskit v1.2)"), `None`, `None`]]]) – A callable used to produce an ordering of the nodes to minimize the number of blocks needed. If not provided, `block_order_op_nodes()` will be used. + + ## Attributes + + ### is\_analysis\_pass + + + Check if the pass is an analysis pass. + + If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + ### is\_transformation\_pass + + + Check if the pass is a transformation pass. + + If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + + + ## Methods + + ### \_\_call\_\_ + + + Runs the pass on circuit. + + **Parameters** + + * **circuit** (*QuantumCircuit*) – The dag on which the pass is run. + * **property\_set** (*PropertySet | dict | None*) – Input/output property set. An analysis pass might change the property set in-place. + + **Return type** + + QuantumCircuit + + **Returns** + + If on transformation pass, the resulting QuantumCircuit. If analysis pass, the input circuit. + + + ### execute + + + Execute optimization task for input Qiskit IR. + + **Parameters** + + * **passmanager\_ir** (`Any`) – Qiskit IR to optimize. + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – State associated with workflow execution by the pass manager itself. + * **callback** (`Optional`\[`Callable`]) – A callback function which is caller per execution of optimization task. + + **Return type** + + `tuple`\[`Any`, [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")] + + **Returns** + + Optimized Qiskit IR and state of the workflow. + + + ### name + + + Name of the pass. + + **Return type** + + `str` + + + ### run + + + Run the ASAPSchedule pass on dag. :type dag: [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)") :param dag: DAG to schedule. :type dag: DAGCircuit + + **Raises** + + * **TranspilerError** – if the circuit is not mapped on physical qubits. + * **TranspilerError** – if conditional bit is added to non-supported instruction. + + **Return type** + + `None` + + **Returns** + + The scheduled DAGCircuit. + + + ### update\_status + + + Update workflow status. + + **Parameters** + + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – Pass manager state to update. + * **run\_state** (`RunState`) – Completion status of current task. + + **Return type** + + [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)") + + **Returns** + + Updated pass manager state. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx new file mode 100644 index 00000000000..37f8703ae96 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx @@ -0,0 +1,142 @@ +--- +title: ASAPScheduleAnalysis +description: API reference for qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis +--- + +# ASAPScheduleAnalysis + + + Dynamic circuits as-soon-as-possible (ASAP) scheduling analysis pass. + + This is a scheduler designed to work for the unique scheduling constraints of the dynamic circuits backends due to the limitations imposed by hardware. This is expected to evolve over time as the dynamic circuit backends also change. + + In its current form this is similar to Qiskit’s ASAP scheduler in which instructions start as early as possible. + + The primary differences are that: + + * **Resets and control-flow currently trigger the end of a “quantum block”. The period between the end** + + of the block and the next is *nondeterministic* ie., we do not know when the next block will begin (as we could be evaluating a classical function of nondeterministic length) and therefore the next block starts at a *relative* t=0. + + * During a measurement it is possible to apply gates in parallel on disjoint qubits. + + * Measurements and resets on disjoint qubits happen simultaneously and are part of the same block. + + Scheduler for dynamic circuit backends. + + **Parameters** + + * **durations** ([`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)")) – Durations of instructions to be used in scheduling. + * **block\_ordering\_callable** (`Optional`\[`Callable`\[\[[`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")], `Generator`\[[`DAGOpNode`](/api/qiskit/qiskit.dagcircuit.DAGOpNode "(in Qiskit v1.2)"), `None`, `None`]]]) – A callable used to produce an ordering of the nodes to minimize the number of blocks needed. If not provided, `block_order_op_nodes()` will be used. + + ## Attributes + + ### is\_analysis\_pass + + + Check if the pass is an analysis pass. + + If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + ### is\_transformation\_pass + + + Check if the pass is a transformation pass. + + If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + + + ## Methods + + ### \_\_call\_\_ + + + Runs the pass on circuit. + + **Parameters** + + * **circuit** (*QuantumCircuit*) – The dag on which the pass is run. + * **property\_set** (*PropertySet | dict | None*) – Input/output property set. An analysis pass might change the property set in-place. + + **Return type** + + QuantumCircuit + + **Returns** + + If on transformation pass, the resulting QuantumCircuit. If analysis pass, the input circuit. + + + ### execute + + + Execute optimization task for input Qiskit IR. + + **Parameters** + + * **passmanager\_ir** (`Any`) – Qiskit IR to optimize. + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – State associated with workflow execution by the pass manager itself. + * **callback** (`Optional`\[`Callable`]) – A callback function which is caller per execution of optimization task. + + **Return type** + + `tuple`\[`Any`, [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")] + + **Returns** + + Optimized Qiskit IR and state of the workflow. + + + ### name + + + Name of the pass. + + **Return type** + + `str` + + + ### run + + + Run the ALAPSchedule pass on dag. :type dag: [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)") :param dag: DAG to schedule. :type dag: DAGCircuit + + **Raises** + + * **TranspilerError** – if the circuit is not mapped on physical qubits. + * **TranspilerError** – if conditional bit is added to non-supported instruction. + + **Return type** + + [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)") + + **Returns** + + The scheduled DAGCircuit. + + + ### update\_status + + + Update workflow status. + + **Parameters** + + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – Pass manager state to update. + * **run\_state** (`RunState`) – Completion status of current task. + + **Return type** + + [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)") + + **Returns** + + Updated pass manager state. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx new file mode 100644 index 00000000000..c1e8b78ccee --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx @@ -0,0 +1,135 @@ +--- +title: BlockBasePadder +description: API reference for qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder +--- + +# BlockBasePadder + + + The base class of padding pass. + + This pass requires one of scheduling passes to be executed before itself. Since there are multiple scheduling strategies, the selection of scheduling pass is left in the hands of the pass manager designer. Once a scheduling analysis pass is run, `node_start_time` is generated in the `property_set`. This information is represented by a python dictionary of the expected instruction execution times keyed on the node instances. The padding pass expects all `DAGOpNode` in the circuit to be scheduled. + + This base class doesn’t define any sequence to interleave, but it manages the location where the sequence is inserted, and provides a set of information necessary to construct the proper sequence. Thus, a subclass of this pass just needs to implement `_pad()` method, in which the subclass constructs a circuit block to insert. This mechanism removes lots of boilerplate logic to manage whole DAG circuits. + + Note that padding pass subclasses should define interleaving sequences satisfying: + + > * Interleaved sequence does not change start time of other nodes + > * Interleaved sequence should have total duration of the provided `time_interval`. + + Any manipulation violating these constraints may prevent this base pass from correctly tracking the start time of each instruction, which may result in violation of hardware alignment constraints. + + ## Attributes + + ### is\_analysis\_pass + + + Check if the pass is an analysis pass. + + If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + ### is\_transformation\_pass + + + Check if the pass is a transformation pass. + + If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + + + ## Methods + + ### \_\_call\_\_ + + + Runs the pass on circuit. + + **Parameters** + + * **circuit** (*QuantumCircuit*) – The dag on which the pass is run. + * **property\_set** (*PropertySet | dict | None*) – Input/output property set. An analysis pass might change the property set in-place. + + **Return type** + + QuantumCircuit + + **Returns** + + If on transformation pass, the resulting QuantumCircuit. If analysis pass, the input circuit. + + + ### execute + + + Execute optimization task for input Qiskit IR. + + **Parameters** + + * **passmanager\_ir** (`Any`) – Qiskit IR to optimize. + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – State associated with workflow execution by the pass manager itself. + * **callback** (`Optional`\[`Callable`]) – A callback function which is caller per execution of optimization task. + + **Return type** + + `tuple`\[`Any`, [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")] + + **Returns** + + Optimized Qiskit IR and state of the workflow. + + + ### name + + + Name of the pass. + + **Return type** + + `str` + + + ### run + + + Run the padding pass on `dag`. + + **Parameters** + + **dag** ([`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")) – DAG to be checked. + + **Returns** + + DAG with idle time filled with instructions. + + **Return type** + + DAGCircuit + + **Raises** + + **TranspilerError** – When a particular node is not scheduled, likely some transform pass is inserted before this node is called. + + + ### update\_status + + + Update workflow status. + + **Parameters** + + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – Pass manager state to update. + * **run\_state** (`RunState`) – Completion status of current task. + + **Return type** + + [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)") + + **Returns** + + Updated pass manager state. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx new file mode 100644 index 00000000000..bd160bb9dd4 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx @@ -0,0 +1,120 @@ +--- +title: DynamicCircuitInstructionDurations +description: API reference for qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations +--- + +# DynamicCircuitInstructionDurations + + + For dynamic circuits the IBM Qiskit backend currently reports instruction durations that differ compared with those required for the legacy Qobj-based path. For now we use this class to report updated InstructionDurations. TODO: This would be mitigated by a specialized Backend/Target for dynamic circuit backends. + + Dynamic circuit instruction durations. + + ## Attributes + + ### MEASURE\_PATCH\_CYCLES + + + + ### MEASURE\_PATCH\_ODD\_OFFSET + + + + ## Methods + + ### from\_backend + + + Construct a `DynamicInstructionDurations` object from the backend. :type backend: [`Backend`](/api/qiskit/qiskit.providers.Backend "(in Qiskit v1.2)") :param backend: backend from which durations (gate lengths) and dt are extracted. + + **Returns** + + The InstructionDurations constructed from backend. + + **Return type** + + DynamicInstructionDurations + + + ### from\_target + + + Construct a `DynamicInstructionDurations` object from the target. :type target: [`Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") :param target: target from which durations (gate lengths) and dt are extracted. + + **Returns** + + The InstructionDurations constructed from backend. + + **Return type** + + DynamicInstructionDurations + + + ### get + + + Get the duration of the instruction with the name, qubits, and parameters. + + Some instructions may have a parameter dependent duration. + + **Parameters** + + * **inst** (*str |* [*qiskit.circuit.Instruction*](/api/qiskit/qiskit.circuit.Instruction "(in Qiskit v1.2)")) – An instruction or its name to be queried. + * **qubits** (*int | list\[int]*) – Qubit indices that the instruction acts on. + * **unit** (*str*) – The unit of duration to be returned. It must be ‘s’ or ‘dt’. + * **parameters** (*list\[float] | None*) – The value of the parameters of the desired instruction. + + **Returns** + + The duration of the instruction on the qubits. + + **Return type** + + float|int + + **Raises** + + **TranspilerError** – No duration is defined for the instruction. + + + ### units\_used + + + Get the set of all units used in this instruction durations. + + **Return type** + + `set`\[`str`] + + **Returns** + + Set of units used in this instruction durations. + + + ### update + + + Update self with inst\_durations (inst\_durations overwrite self). Overrides the default durations for certain hardcoded instructions. + + **Parameters** + + * **inst\_durations** (`Union`\[`List`\[`Tuple`\[`str`, `Optional`\[`Iterable`\[`int`]], `float`, `Optional`\[`Iterable`\[`float`]], `str`]], `List`\[`Tuple`\[`str`, `Optional`\[`Iterable`\[`int`]], `float`, `Optional`\[`Iterable`\[`float`]]]], `List`\[`Tuple`\[`str`, `Optional`\[`Iterable`\[`int`]], `float`, `str`]], `List`\[`Tuple`\[`str`, `Optional`\[`Iterable`\[`int`]], `float`]], [`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)"), `None`]) – Instruction durations to be merged into self (overwriting self). + * **dt** (`Optional`\[`float`]) – Sampling duration in seconds of the target backend. + + **Returns** + + The updated InstructionDurations. + + **Return type** + + InstructionDurations + + **Raises** + + **TranspilerError** – If the format of instruction\_durations is invalid. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx new file mode 100644 index 00000000000..261c35f5685 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx @@ -0,0 +1,149 @@ +--- +title: PadDelay +description: API reference for qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay +--- + +# PadDelay + + + Padding idle time with Delay instructions. + + Consecutive delays will be merged in the output of this pass. + + The ASAP-scheduled circuit output may become + + ```python + ┌────────────────┐ + q_0: ┤ Delay(160[dt]) ├──■── + └─────┬───┬──────┘┌─┴─┐ + q_1: ──────┤ X ├───────┤ X ├ + └───┘ └───┘ + ``` + + Note that the additional idle time of 60dt on the `q_0` wire coming from the duration difference between `Delay` of 100dt (`q_0`) and `XGate` of 160 dt (`q_1`) is absorbed in the delay instruction on the `q_0` wire, i.e. in total 160 dt. + + See [`BlockBasePadder`](qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder "qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder") pass for details. + + Create new padding delay pass. + + **Parameters** + + * **durations** ([`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)")) – Durations of instructions to be used in scheduling. + * **fill\_very\_end** (`bool`) – Set `True` to fill the end of circuit with delay. + * **schedule\_idle\_qubits** (`bool`) – Set to true if you’d like a delay inserted on idle qubits. This is useful for timeline visualizations, but may cause issues for execution on large backends. + * **block\_ordering\_callable** (`Optional`\[`Callable`\[\[[`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")], `Generator`\[[`DAGOpNode`](/api/qiskit/qiskit.dagcircuit.DAGOpNode "(in Qiskit v1.2)"), `None`, `None`]]]) – A callable used to produce an ordering of the nodes to minimize the number of blocks needed. If not provided, `block_order_op_nodes()` will be used. + + ## Attributes + + ### is\_analysis\_pass + + + Check if the pass is an analysis pass. + + If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + ### is\_transformation\_pass + + + Check if the pass is a transformation pass. + + If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + + + ## Methods + + ### \_\_call\_\_ + + + Runs the pass on circuit. + + **Parameters** + + * **circuit** (*QuantumCircuit*) – The dag on which the pass is run. + * **property\_set** (*PropertySet | dict | None*) – Input/output property set. An analysis pass might change the property set in-place. + + **Return type** + + QuantumCircuit + + **Returns** + + If on transformation pass, the resulting QuantumCircuit. If analysis pass, the input circuit. + + + ### execute + + + Execute optimization task for input Qiskit IR. + + **Parameters** + + * **passmanager\_ir** (`Any`) – Qiskit IR to optimize. + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – State associated with workflow execution by the pass manager itself. + * **callback** (`Optional`\[`Callable`]) – A callback function which is caller per execution of optimization task. + + **Return type** + + `tuple`\[`Any`, [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")] + + **Returns** + + Optimized Qiskit IR and state of the workflow. + + + ### name + + + Name of the pass. + + **Return type** + + `str` + + + ### run + + + Run the padding pass on `dag`. + + **Parameters** + + **dag** ([`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")) – DAG to be checked. + + **Returns** + + DAG with idle time filled with instructions. + + **Return type** + + DAGCircuit + + **Raises** + + **TranspilerError** – When a particular node is not scheduled, likely some transform pass is inserted before this node is called. + + + ### update\_status + + + Update workflow status. + + **Parameters** + + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – Pass manager state to update. + * **run\_state** (`RunState`) – Completion status of current task. + + **Return type** + + [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)") + + **Returns** + + Updated pass manager state. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx new file mode 100644 index 00000000000..1735443239d --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx @@ -0,0 +1,286 @@ +--- +title: PadDynamicalDecoupling +description: API reference for qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling +--- + +# PadDynamicalDecoupling + + + Dynamical decoupling insertion pass for IBM dynamic circuit backends. + + This pass works on a scheduled, physical circuit. It scans the circuit for idle periods of time (i.e. those containing delay instructions) and inserts a DD sequence of gates in those spots. These gates amount to the identity, so do not alter the logical action of the circuit, but have the effect of mitigating decoherence in those idle periods. As a special case, the pass allows a length-1 sequence (e.g. \[XGate()]). In this case the DD insertion happens only when the gate inverse can be absorbed into a neighboring gate in the circuit (so we would still be replacing Delay with something that is equivalent to the identity). This can be used, for instance, as a Hahn echo. This pass ensures that the inserted sequence preserves the circuit exactly (including global phase). + + ```python + import numpy as np + from qiskit.circuit import QuantumCircuit + from qiskit.circuit.library import XGate + from qiskit.transpiler import PassManager, InstructionDurations + from qiskit.visualization import timeline_drawer + + from qiskit_ibm_runtime.transpiler.passes.scheduling import ALAPScheduleAnalysis + from qiskit_ibm_runtime.transpiler.passes.scheduling import PadDynamicalDecoupling + + circ = QuantumCircuit(4) + circ.h(0) + circ.cx(0, 1) + circ.cx(1, 2) + circ.cx(2, 3) + circ.measure_all() + durations = InstructionDurations( + [("h", 0, 50), ("cx", [0, 1], 700), ("reset", None, 10), + ("cx", [1, 2], 200), ("cx", [2, 3], 300), + ("x", None, 50), ("measure", None, 1000)] + ) + ``` + + ```python + # balanced X-X sequence on all qubits + dd_sequence = [XGate(), XGate()] + pm = PassManager([ALAPScheduleAnalysis(durations), + PadDynamicalDecoupling(durations, dd_sequence)]) + circ_dd = pm.run(circ) + circ_dd.draw() + ``` + + ```python + ┌───┐ ┌───────────────┐ ┌───┐ » + q_0: ──────┤ H ├─────────■──┤ Delay(96[dt]) ├──────┤ X ├──────» + ┌─────┴───┴─────┐ ┌─┴─┐└───────────────┘┌─────┴───┴─────┐» + q_1: ┤ Delay(50[dt]) ├─┤ X ├────────■────────┤ Delay(48[dt]) ├» + ├───────────────┴┐└───┘ ┌─┴─┐ └───────────────┘» + q_2: ┤ Delay(750[dt]) ├───────────┤ X ├──────────────■────────» + ├────────────────┤ └───┘ ┌─┴─┐ » + q_3: ┤ Delay(950[dt]) ├────────────────────────────┤ X ├──────» + └────────────────┘ └───┘ » + meas: 4/═════════════════════════════════════════════════════════» + » + « ┌────────────────┐ ┌───┐ ┌───────────────┐ » + « q_0: ┤ Delay(208[dt]) ├──────┤ X ├──────┤ Delay(96[dt]) ├─────────────────» + « └─────┬───┬──────┘┌─────┴───┴─────┐└─────┬───┬─────┘┌───────────────┐» + « q_1: ──────┤ X ├───────┤ Delay(96[dt]) ├──────┤ X ├──────┤ Delay(56[dt]) ├» + « └───┘ └───────────────┘ └───┘ └───────────────┘» + « q_2: ─────────────────────────────────────────────────────────────────────» + « » + « q_3: ─────────────────────────────────────────────────────────────────────» + « » + «meas: 4/═════════════════════════════════════════════════════════════════════» + « » + « ░ ┌─┐ + « q_0: ─░─┤M├───────── + « ░ └╥┘┌─┐ + « q_1: ─░──╫─┤M├────── + « ░ ║ └╥┘┌─┐ + « q_2: ─░──╫──╫─┤M├─── + « ░ ║ ║ └╥┘┌─┐ + « q_3: ─░──╫──╫──╫─┤M├ + « ░ ║ ║ ║ └╥┘ + «meas: 4/════╩══╩══╩══╩═ + « 0 1 2 3 + ``` + + ```python + # Uhrig sequence on qubit 0 + n = 8 + dd_sequence = [XGate()] * n + def uhrig_pulse_location(k): + return np.sin(np.pi * (k + 1) / (2 * n + 2)) ** 2 + spacings = [] + for k in range(n): + spacings.append(uhrig_pulse_location(k) - sum(spacings)) + spacings.append(1 - sum(spacings)) + pm = PassManager( + [ + ALAPScheduleAnalysis(durations), + PadDynamicalDecoupling(durations, dd_sequence, qubits=[0], spacings=spacings), + ] + ) + circ_dd = pm.run(circ) + circ_dd.draw() + ``` + + ```python + ┌───┐ ┌────────────────┐ ░ ┌─┐ » + q_0: ──────┤ H ├─────────■──┤ Delay(500[dt]) ├───────────────────░─┤M├──────» + ┌─────┴───┴─────┐ ┌─┴─┐└────────────────┘┌────────────────┐ ░ └╥┘┌─┐ » + q_1: ┤ Delay(50[dt]) ├─┤ X ├────────■─────────┤ Delay(300[dt]) ├─░──╫─┤M├───» + ├───────────────┴┐└───┘ ┌─┴─┐ └────────────────┘ ░ ║ └╥┘┌─┐» + q_2: ┤ Delay(750[dt]) ├───────────┤ X ├───────────────■──────────░──╫──╫─┤M├» + ├────────────────┤ └───┘ ┌─┴─┐ ░ ║ ║ └╥┘» + q_3: ┤ Delay(950[dt]) ├─────────────────────────────┤ X ├────────░──╫──╫──╫─» + └────────────────┘ └───┘ ░ ║ ║ ║ » + meas: 4/═══════════════════════════════════════════════════════════════╩══╩══╩═» + 0 1 2 » + « + « q_0: ─── + « + « q_1: ─── + « + « q_2: ─── + « ┌─┐ + « q_3: ┤M├ + « └╥┘ + «meas: 4/═╩═ + « 3 + ``` + + + You need to call [`ALAPScheduleAnalysis`](qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis "qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis") before running dynamical decoupling to guarantee your circuit satisfies acquisition alignment constraints for dynamic circuit backends. + + + Dynamical decoupling initializer. + + **Parameters** + + * **durations** ([`InstructionDurations`](/api/qiskit/qiskit.transpiler.InstructionDurations "(in Qiskit v1.2)")) – Durations of instructions to be used in scheduling. + + * **dd\_sequences** (`Union`\[`List`\[[`Gate`](/api/qiskit/qiskit.circuit.Gate "(in Qiskit v1.2)")], `List`\[`List`\[[`Gate`](/api/qiskit/qiskit.circuit.Gate "(in Qiskit v1.2)")]]]) – Sequence of gates to apply in idle spots. Alternatively a list of gate sequences may be supplied that will preferentially be inserted if there is a delay of sufficient duration. This may be tuned by the optionally supplied `sequence_min_length_ratios`. + + * **qubits** (`Optional`\[`List`\[`int`]]) – Physical qubits on which to apply DD. If None, all qubits will undergo DD (when possible). + + * **spacings** (`Union`\[`List`\[`List`\[`float`]], `List`\[`float`], `None`]) – A list of lists of spacings between the DD gates. The available slack will be divided according to this. The list length must be one more than the length of dd\_sequence, and the elements must sum to 1. If None, a balanced spacing will be used \[d/2, d, d, …, d, d, d/2]. This spacing only applies to the first subcircuit, if a `coupling_map` is specified + + * **skip\_reset\_qubits** (`bool`) – If True, does not insert DD on idle periods that immediately follow initialized/reset qubits (as qubits in the ground state are less susceptible to decoherence). + + * **pulse\_alignment** (`int`) – The hardware constraints for gate timing allocation. This is usually provided from `backend.configuration().timing_constraints`. If provided, the delay length, i.e. `spacing`, is implicitly adjusted to satisfy this constraint. + + * **extra\_slack\_distribution** (`str`) – + + The option to control the behavior of DD sequence generation. The duration of the DD sequence should be identical to an idle time in the scheduled quantum circuit, however, the delay in between gates comprising the sequence should be integer number in units of dt, and it might be further truncated when `pulse_alignment` is specified. This sometimes results in the duration of the created sequence being shorter than the idle time that you want to fill with the sequence, i.e. extra slack. This option takes following values. + + > * ”middle”: Put the extra slack to the interval at the middle of the sequence. + > * ”edges”: Divide the extra slack as evenly as possible into intervals at beginning and end of the sequence. + + * **sequence\_min\_length\_ratios** (`Union`\[`int`, `List`\[`int`], `None`]) – List of minimum delay length to DD sequence ratio to satisfy in order to insert the DD sequence. For example if the X-X dynamical decoupling sequence is 320dt samples long and the available delay is 384dt it has a ratio of 384dt/320dt=1.2. From the perspective of dynamical decoupling this is likely to add more control noise than decoupling error rate reductions. The defaults value is 2.0. + + * **insert\_multiple\_cycles** (`bool`) – If the available duration exceeds 2\*sequence\_min\_length\_ratio\*duration(dd\_sequence) enable the insertion of multiple rounds of the dynamical decoupling sequence in that delay. + + * **coupling\_map** (`Optional`\[[`CouplingMap`](/api/qiskit/qiskit.transpiler.CouplingMap "(in Qiskit v1.2)")]) – directed graph representing the coupling map for the device. Specifying a coupling map partitions the device into subcircuits, in order to apply DD sequences with different pulse spacings within each. Currently support 2 subcircuits. + + * **alt\_spacings** (`Union`\[`List`\[`List`\[`float`]], `List`\[`float`], `None`]) – A list of lists of spacings between the DD gates, for the second subcircuit, as determined by the coupling map. If None, a balanced spacing that is staggered with respect to the first subcircuit will be used \[d, d, d, …, d, d, 0]. + + * **schedule\_idle\_qubits** (`bool`) – Set to true if you’d like a delay inserted on idle qubits. This is useful for timeline visualizations, but may cause issues for execution on large backends. + + * **dd\_barrier** (`Optional`\[`str`]) – only apply DD to delays terminating with a barrier whose label contains the specified string + + * **block\_ordering\_callable** (`Optional`\[`Callable`\[\[[`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")], `Generator`\[[`DAGOpNode`](/api/qiskit/qiskit.dagcircuit.DAGOpNode "(in Qiskit v1.2)"), `None`, `None`]]]) – A callable used to produce an ordering of the nodes to minimize the number of blocks needed. If not provided, `block_order_op_nodes()` will be used. + + **Raises** + + * **TranspilerError** – When invalid DD sequence is specified. + * **TranspilerError** – When pulse gate with the duration which is non-multiple of the alignment constraint value is found. + * **TranspilerError** – When the coupling map is not supported (i.e., if degree > 3) + + ## Attributes + + ### is\_analysis\_pass + + + Check if the pass is an analysis pass. + + If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + ### is\_transformation\_pass + + + Check if the pass is a transformation pass. + + If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + + + ## Methods + + ### \_\_call\_\_ + + + Runs the pass on circuit. + + **Parameters** + + * **circuit** (*QuantumCircuit*) – The dag on which the pass is run. + * **property\_set** (*PropertySet | dict | None*) – Input/output property set. An analysis pass might change the property set in-place. + + **Return type** + + QuantumCircuit + + **Returns** + + If on transformation pass, the resulting QuantumCircuit. If analysis pass, the input circuit. + + + ### execute + + + Execute optimization task for input Qiskit IR. + + **Parameters** + + * **passmanager\_ir** (`Any`) – Qiskit IR to optimize. + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – State associated with workflow execution by the pass manager itself. + * **callback** (`Optional`\[`Callable`]) – A callback function which is caller per execution of optimization task. + + **Return type** + + `tuple`\[`Any`, [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")] + + **Returns** + + Optimized Qiskit IR and state of the workflow. + + + ### name + + + Name of the pass. + + **Return type** + + `str` + + + ### run + + + Run the padding pass on `dag`. + + **Parameters** + + **dag** ([`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)")) – DAG to be checked. + + **Returns** + + DAG with idle time filled with instructions. + + **Return type** + + DAGCircuit + + **Raises** + + **TranspilerError** – When a particular node is not scheduled, likely some transform pass is inserted before this node is called. + + + ### update\_status + + + Update workflow status. + + **Parameters** + + * **state** ([`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)")) – Pass manager state to update. + * **run\_state** (`RunState`) – Completion status of current task. + + **Return type** + + [`PassManagerState`](/api/qiskit/qiskit.passmanager.PassManagerState "(in Qiskit v1.2)") + + **Returns** + + Updated pass manager state. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.mdx new file mode 100644 index 00000000000..20d03fee56e --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling.mdx @@ -0,0 +1,372 @@ +--- +title: scheduling +description: API reference for qiskit_ibm_runtime.transpiler.passes.scheduling +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling +--- + + + + + +# Transpiler scheduling passes + +`qiskit_ibm_runtime.transpiler.passes.scheduling` + +A collection of scheduling passes for working with IBM Quantum’s next-generation backends that support advanced “dynamic circuit” capabilities. Ie., circuits with support for classical control-flow/feedback based off of measurement results. + + + You should not mix these scheduling passes with Qiskit’s builtin scheduling passes as they will negatively interact with the scheduling routines for dynamic circuits. This includes setting `scheduling_method` in [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "(in Qiskit v1.2)") or [`generate_preset_pass_manager()`](/api/qiskit/transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "(in Qiskit v1.2)"). + + +## Classes + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| [`BlockBasePadder`](qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder "qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder")(\[schedule\_idle\_qubits, ...]) | The base class of padding pass. | +| [`ALAPScheduleAnalysis`](qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis "qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis")(durations\[, ...]) | Dynamic circuits as-late-as-possible (ALAP) scheduling analysis pass. | +| [`ASAPScheduleAnalysis`](qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis "qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis")(durations\[, ...]) | Dynamic circuits as-soon-as-possible (ASAP) scheduling analysis pass. | +| [`DynamicCircuitInstructionDurations`](qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations "qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations")(\[...]) | For dynamic circuits the IBM Qiskit backend currently reports instruction durations that differ compared with those required for the legacy Qobj-based path. | +| [`PadDelay`](qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay "qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay")(durations\[, fill\_very\_end, ...]) | Padding idle time with Delay instructions. | +| [`PadDynamicalDecoupling`](qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling "qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling")(durations, dd\_sequences) | Dynamical decoupling insertion pass for IBM dynamic circuit backends. | + +## Example usage + +Below we demonstrate how to schedule and pad a teleportation circuit with delays for a dynamic circuit backend’s execution model: + +```python +from qiskit.circuit import ClassicalRegister, QuantumCircuit, QuantumRegister +from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager +from qiskit.transpiler.passmanager import PassManager + +from qiskit_ibm_runtime.transpiler.passes.scheduling import DynamicCircuitInstructionDurations +from qiskit_ibm_runtime.transpiler.passes.scheduling import ALAPScheduleAnalysis +from qiskit_ibm_runtime.transpiler.passes.scheduling import PadDelay +from qiskit_ibm_runtime.fake_provider import FakeJakartaV2 + +backend = FakeJakartaV2() + +# Use this duration class to get appropriate durations for dynamic +# circuit backend scheduling +durations = DynamicCircuitInstructionDurations.from_backend(backend) +# Generate the main Qiskit transpile passes. +pm = generate_preset_pass_manager(optimization_level=1, backend=backend) +# Configure the as-late-as-possible scheduling pass +pm.scheduling = PassManager([ALAPScheduleAnalysis(durations), PadDelay(durations)]) + +qr = QuantumRegister(3) +crz = ClassicalRegister(1, name="crz") +crx = ClassicalRegister(1, name="crx") +result = ClassicalRegister(1, name="result") + +teleport = QuantumCircuit(qr, crz, crx, result, name="Teleport") + +teleport.h(qr[1]) +teleport.cx(qr[1], qr[2]) +teleport.cx(qr[0], qr[1]) +teleport.h(qr[0]) +teleport.measure(qr[0], crz) +teleport.measure(qr[1], crx) +with teleport.if_test((crz, 1)): + teleport.z(qr[2]) +with teleport.if_test((crx, 1)): + teleport.x(qr[2]) +teleport.measure(qr[2], result) + +# Transpile. +scheduled_teleport = pm.run(teleport) + +scheduled_teleport.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_0\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_0_0.png) + +Instead of padding with delays we may also insert a dynamical decoupling sequence using the [`PadDynamicalDecoupling`](qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling "qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling") pass as shown below: + +```python +from qiskit.circuit.library import XGate + +from qiskit_ibm_runtime.transpiler.passes.scheduling import PadDynamicalDecoupling + + +dd_sequence = [XGate(), XGate()] + +pm = generate_preset_pass_manager(optimization_level=1, backend=backend) +pm.scheduling = PassManager( + [ + ALAPScheduleAnalysis(durations), + PadDynamicalDecoupling(durations, dd_sequence), + ] +) + +dd_teleport = pm.run(teleport) + +dd_teleport.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_1\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_1_0.png) + +When compiling a circuit with Qiskit, it is more efficient and more robust to perform all the transformations in a single transpilation. This has been done above by extending Qiskit’s preset pass managers. For example, Qiskit’s [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "(in Qiskit v1.2)") function internally builds its pass set by using [`generate_preset_pass_manager()`](/api/qiskit/transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "(in Qiskit v1.2)"). This returns instances of [`StagedPassManager`](/api/qiskit/qiskit.transpiler.StagedPassManager "(in Qiskit v1.2)"), which can be extended. + + + +## Scheduling old format c\_if conditioned gates + +Scheduling with old format `c_if` conditioned gates is not supported. + +```python +qc_c_if = QuantumCircuit(1, 1) +qc_c_if.x(0).c_if(0, 1) +qc_c_if.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_2\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_2_0.png) + +The [`IBMBackend`](qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.IBMBackend") configures a translation plugin `IBMTranslationPlugin` to automatically apply transformations and optimizations for IBM hardware backends when invoking [`transpile()`](/api/qiskit/compiler#qiskit.compiler.transpile "(in Qiskit v1.2)"). This will automatically convert all old style `c_if` conditioned gates to new-style control-flow. We may then schedule the transpiled circuit without further modification. + +```python +# Temporary workaround for mock backends. For real backends this is not required. +backend.get_translation_stage_plugin = lambda: "ibm_dynamic_circuits" + +pm = generate_preset_pass_manager(optimization_level=1, backend=backend) +pm.scheduling = PassManager( + [ + ALAPScheduleAnalysis(durations), + PadDynamicalDecoupling(durations, dd_sequence), + ] +) + +qc_if_dd = pm.run(qc_c_if, backend) +qc_if_dd.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_3\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_3_0.png) + +If you are not using the transpiler plugin stages to work around this please manually run the pass [`qiskit.transpiler.passes.ConvertConditionsToIfOps`](/api/qiskit/qiskit.transpiler.passes.ConvertConditionsToIfOps "(in Qiskit v1.2)") prior to your scheduling pass. + +```python +from qiskit.transpiler.passes import ConvertConditionsToIfOps + +pm = generate_preset_pass_manager(optimization_level=1, backend=backend) +pm.scheduling = PassManager( + [ + ConvertConditionsToIfOps(), + ALAPScheduleAnalysis(durations), + PadDelay(durations), + ] +) + +qc_if_dd = pm.run(qc_c_if) +qc_if_dd.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_4\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_4_0.png) + + + +## Exploiting IBM backend’s local parallel “fast-path” + +IBM quantum hardware supports a localized “fast-path” which enables a block of gates applied to a *single qubit* that are conditional on an immediately predecessor measurement *of the same qubit* to be completed with lower latency. The hardware is also able to do this in *parallel* on disjoint qubits that satisfy this condition. + +For example, the conditional gates below are performed in parallel with lower latency as the measurements flow directly into the conditional blocks which in turn only apply gates to the same measurement qubit. + +```python +qc = QuantumCircuit(2, 2) +qc.measure(0, 0) +qc.measure(1, 1) +# Conditional blocks will be performed in parallel in the hardware +with qc.if_test((0, 1)): + qc.x(0) +with qc.if_test((1, 1)): + qc.x(1) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_5\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_5_0.png) + +The circuit below will not use the fast-path as the conditional gate is on a different qubit than the measurement qubit. + +```python +qc = QuantumCircuit(2, 2) +qc.measure(0, 0) +with qc.if_test((0, 1)): + qc.x(1) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_6\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_6_0.png) + +Similarly, the circuit below contains gates on multiple qubits and will not be performed using the fast-path. + +```python +qc = QuantumCircuit(2, 2) +qc.measure(0, 0) +with qc.if_test((0, 1)): + qc.x(0) + qc.x(1) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_7\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_7_0.png) + +A fast-path block may contain multiple gates as long as they are on the fast-path qubit. If there are multiple fast-path blocks being performed in parallel each block will be padded out to the duration of the longest block. + +```python +qc = QuantumCircuit(2, 2) +qc.measure(0, 0) +qc.measure(1, 1) +# Conditional blocks will be performed in parallel in the hardware +with qc.if_test((0, 1)): + qc.x(0) + # Will be padded out to a duration of 1600 on the backend. +with qc.if_test((1, 1)): + qc.delay(1600, 1) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_8\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_8_0.png) + +This behavior is also applied to the else condition of a fast-path eligible branch. + +```python +qc = QuantumCircuit(1, 1) +qc.measure(0, 0) +# Conditional blocks will be performed in parallel in the hardware +with qc.if_test((0, 1)) as else_: + qc.x(0) + # Will be padded out to a duration of 1600 on the backend. +with else_: + qc.delay(1600, 0) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_9\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_9_0.png) + +If a single measurement result is used with several conditional blocks, if there is a fast-path eligible block it will be applied followed by the non-fast-path blocks which will execute with the standard higher latency conditional branch. + +```python +qc = QuantumCircuit(2, 2) +qc.measure(0, 0) +# Conditional blocks will be performed in parallel in the hardware +with qc.if_test((0, 1)): + # Uses fast-path + qc.x(0) +with qc.if_test((0, 1)): + # Does not use fast-path + qc.x(1) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_10\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_10_0.png) + +If you wish to prevent the usage of the fast-path you may insert a barrier between the measurement and the conditional branch. + +```python +qc = QuantumCircuit(1, 2) +qc.measure(0, 0) +# Barrier prevents the fast-path. +qc.barrier() +with qc.if_test((0, 1)): + qc.x(0) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_11\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_11_0.png) + +Conditional measurements are not eligible for the fast-path. + +```python +qc = QuantumCircuit(1, 2) +qc.measure(0, 0) +with qc.if_test((0, 1)): + # Does not use the fast-path + qc.measure(0, 1) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_12\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_12_0.png) + +Similarly nested control-flow is not eligible. + +```python +qc = QuantumCircuit(1, 1) +qc.measure(0, 0) +with qc.if_test((0, 1)): + # Does not use the fast-path + qc.x(0) + with qc.if_test((0, 1)): + qc.x(0) + +qc.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_13\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_13_0.png) + +The scheduler is aware of the fast-path behavior and will not insert delays on idle qubits in blocks that satisfy the fast-path conditions so as to avoid preventing the backend compiler from performing the necessary optimizations to utilize the fast-path. If there are fast-path blocks that will be performed in parallel they currently *will not* be padded out by the scheduler to ensure they are of the same duration in Qiskit + +```python +dd_sequence = [XGate(), XGate()] + +pm = PassManager( + [ + ALAPScheduleAnalysis(durations), + PadDynamicalDecoupling(durations, dd_sequence), + ] +) + +qc = QuantumCircuit(2, 2) +qc.measure(0, 0) +qc.measure(1, 1) +with qc.if_test((0, 1)): + qc.x(0) + # Is currently not padded to ensure + # a duration of 1000. If you desire + # this you would need to manually add + # qc.delay(840, 0) +with qc.if_test((1, 1)): + qc.delay(1000, 0) + + +qc.draw(output="mpl", style="iqp") + +qc_dd = pm.run(qc) + +qc_dd.draw(output="mpl", style="iqp") +``` + +![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_14\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_14_0.png) + + + If there are qubits that are *not* involved in a fast-path decision it is not currently possible to use them in a fast-path branch in parallel with the fast-path qubits resulting from a measurement. This will be revised in the future as we further improve these capabilities. + + For example: + + ```python + qc = QuantumCircuit(3, 2) + qc.x(1) + qc.measure(0, 0) + with qc.if_test((0, 1)): + qc.x(0) + # Qubit 1 sits idle throughout the fast-path decision + with qc.if_test((1, 0)): + # Qubit 2 is idle but there is no measurement + # to make it fast-path eligible. This will + # however avoid a communication event in the hardware + # since the condition is compile time evaluated. + qc.x(2) + + qc.draw(output="mpl", style="iqp") + ``` + + ![../\_images/qiskit\_ibm\_runtime.transpiler.passes.scheduling\_15\_0.png](/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_15_0.png) + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx new file mode 100644 index 00000000000..58f7eb6f2c3 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx @@ -0,0 +1,110 @@ +--- +title: LayerError +description: API reference for qiskit_ibm_runtime.utils.noise_learner_result.LayerError +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.utils.noise_learner_result.LayerError +--- + +# LayerError + + + The error channel (in Pauli-Lindblad format) of a single layer of instructions. + + **Parameters** + + * **circuit** ([`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)")) – A circuit whose noise has been learnt. + * **qubits** (`Sequence`\[`int`]) – The labels of the qubits in the `circuit`. + * **error** (`Optional`\[[`PauliLindbladError`](qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError")]) – The Pauli Lindblad error channel affecting the `circuit`, or `None` if the error channel is either unknown or explicitly disabled. + + **Raises** + + **ValueError** – If `circuit`, `qubits`, and `error` have mismatching number of qubits. + + ## Attributes + + ### circuit + + + The circuit in this `LayerError`. + + **Return type** + + [`QuantumCircuit`](/api/qiskit/qiskit.circuit.QuantumCircuit "(in Qiskit v1.2)") + + + ### error + + + The error channel in this `LayerError`, or `None` if the error channel is either unknown or explicitly disabled. + + **Return type** + + `Optional`\[[`PauliLindbladError`](qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError")] + + + ### generators + + + (DEPRECATED) The Pauli Lindblad generators of the error channel in this `LayerError`. + + **Return type** + + [`PauliList`](/api/qiskit/qiskit.quantum_info.PauliList "(in Qiskit v1.2)") + + + ### num\_qubits + + + The number of qubits in this [`LayerError`](#qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError"). + + **Return type** + + `int` + + + ### qubits + + + The qubits in this `LayerError`. + + **Return type** + + `list`\[`int`] + + + ### rates + + + (DEPRECATED) The Lindblad generator rates of the error channel in this `LayerError`. + + **Return type** + + [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v2.1)")\[`Any`, [`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`float64`]] + + + ## Methods + + ### draw\_map + + + Draw a map view of a this layer error. + + **Parameters** + + * **embedding** (`Union`\[`Embedding`, [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)")]) – An `Embedding` object containing the coordinates and coupling map to draw the layer error on, or a backend to generate an `Embedding` for. + * **colorscale** (`str`) – The colorscale used to show the rates of this layer error. + * **color\_no\_data** (`str`) – The color used for qubits and edges for which no data is available. + * **num\_edge\_segments** (`int`) – The number of equal-sized segments that edges are made of. + * **edge\_width** (`float`) – The line width of the edges in pixels. + * **height** (`int`) – The height of the returned figure. + * **background\_color** (`str`) – The background color. + * **radius** (`float`) – The radius of the pie charts representing the qubits. + * **width** (`int`) – The width of the returned figure. + + **Return type** + + `Figure` + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx new file mode 100644 index 00000000000..9017c52773b --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx @@ -0,0 +1,96 @@ +--- +title: PauliLindbladError +description: API reference for qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError +--- + +# PauliLindbladError + + + A Pauli error channel generated by a Pauli Lindblad dissipators. + + This operator represents an N-qubit quantum error channel $E(\rho) = e^{\sum_j r_j D_{P_j}}(\rho)$ generated by Pauli Lindblad dissipators $D_P(\rho) = P \rho P - \rho$, where $P_j$ are N-qubit `Pauli` operators. + + The list of Pauli generator terms are stored as a `PauliList` and can be accessed via the [`generators`](#qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.generators "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.generators") attribute. The array of dissipator rates $r_j$ can be accessed via the [`rates`](#qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.rates "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.rates") attribute. + + The equivalent Pauli error channel can be constructed as a composition of single-Pauli channel terms + +$$ +E = e^{\sum_j r_j D_{P_j}} = \prod_j e^{r_j D_{P_j}} += prod_j \left( (1 - p_j) S_I + p_j S_{P_j} \right) +$$ + + where $p_j = \frac12 - \frac12 e^{-2 r_j}$ \[1]. + + **Parameters** + + * **generators** ([`PauliList`](/api/qiskit/qiskit.quantum_info.PauliList "(in Qiskit v1.2)")) – A list of the Pauli Lindblad generators for the error channel. + * **rates** (`Sequence`\[`float`]) – A list of the rates for the Pauli-Lindblad `generators`. + + **Raises** + + **ValueError** – If `generators` and `rates` have different lengths. + + **References** + + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + + ## Attributes + + ### generators + + + The Pauli Lindblad generators of this [`PauliLindbladError`](#qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError"). + + **Return type** + + [`PauliList`](/api/qiskit/qiskit.quantum_info.PauliList "(in Qiskit v1.2)") + + + ### num\_qubits + + + The number of qubits in this [`PauliLindbladError`](#qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError"). + + **Return type** + + `int` + + + ### rates + + + The Lindblad generator rates of this quantum error. + + **Return type** + + [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v2.1)")\[`Any`, [`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[`float64`]] + + + ## Methods + + ### restrict\_num\_bodies + + + The [`PauliLindbladError`](#qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError") containing only those terms acting on exactly `num_qubits` qubits. + + **Parameters** + + **num\_qubits** (`int`) – The number of qubits that the returned error acts on. + + **Return type** + + [`PauliLindbladError`](#qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError") + + **Returns** + + The error containing only those terms acting on exactly `num_qubits` qubits. + + **Raises** + + **ValueError** – If `num_qubits` is smaller than `0`. + + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx new file mode 100644 index 00000000000..d3c01120660 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx @@ -0,0 +1,39 @@ +--- +title: draw_layer_error_map +description: API reference for qiskit_ibm_runtime.visualization.draw_layer_error_map +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit_ibm_runtime.visualization.draw_layer_error_map +--- + + + +# draw\_layer\_error\_map + + + Draw a map view of a [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError"). + + **Parameters** + + * **layer\_error** ([`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError")) – The [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError") to draw. + * **embedding** (`Union`\[`Embedding`, [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)")]) – An `Embedding` object containing the coordinates and coupling map to draw the layer error on, or a backend to generate an `Embedding` for. + * **colorscale** (`str`) – The colorscale used to show the rates of `layer_error`. + * **color\_no\_data** (`str`) – The color used for qubits and edges for which no data is available. + * **num\_edge\_segments** (`int`) – The number of equal-sized segments that edges are made of. + * **edge\_width** (`float`) – The line width of the edges in pixels. + * **height** (`int`) – The height of the returned figure. + * **background\_color** (`str`) – The background color. + * **radius** (`float`) – The radius of the pie charts representing the qubits. + * **width** (`int`) – The width of the returned figure. + + **Raises** + + * **ValueError** – If the given coordinates are incompatible with the specified backend. + * **ValueError** – If `backend` has no coupling map. + * **ModuleNotFoundError** – If the required `plotly` dependencies cannot be imported. + + **Return type** + + `Figure` + + diff --git a/docs/api/qiskit-ibm-runtime/0.31/runtime_service.mdx b/docs/api/qiskit-ibm-runtime/0.31/runtime_service.mdx new file mode 100644 index 00000000000..2bec2ee8b14 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/runtime_service.mdx @@ -0,0 +1,168 @@ +--- +title: qiskit_ibm_runtime +description: API reference for qiskit_ibm_runtime +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime +--- + + + + + +# Qiskit Runtime + +`qiskit_ibm_runtime` + +Modules related to Qiskit Runtime IBM Client. + +Qiskit Runtime is a new architecture that streamlines computations requiring many iterations. These experiments will execute significantly faster within its improved hybrid quantum/classical process. + +## Primitives and sessions + +Qiskit Runtime has two predefined primitives: `Sampler` and `Estimator`. These primitives provide a simplified interface for performing foundational quantum computing tasks while also accounting for the latest developments in quantum hardware and software. + +Qiskit Runtime also has the concept of a session. Jobs submitted within a session are prioritized by the scheduler. A session allows you to make iterative calls to the quantum computer more efficiently. + +Below is an example of using primitives within a session: + +```python +from qiskit_ibm_runtime import QiskitRuntimeService, Session +from qiskit_ibm_runtime import SamplerV2 as Sampler +from qiskit_ibm_runtime import EstimatorV2 as Estimator +from qiskit.circuit.library import RealAmplitudes +from qiskit.circuit import QuantumCircuit, QuantumRegister, ClassicalRegister +from qiskit.quantum_info import SparsePauliOp +from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + +# Initialize account. +service = QiskitRuntimeService() + +# Prepare inputs. +psi = RealAmplitudes(num_qubits=2, reps=2) +H1 = SparsePauliOp.from_list([("II", 1), ("IZ", 2), ("XI", 3)]) +theta = [0, 1, 1, 2, 3, 5] +# Bell Circuit +qr = QuantumRegister(2, name="qr") +cr = ClassicalRegister(2, name="cr") +qc = QuantumCircuit(qr, cr, name="bell") +qc.h(qr[0]) +qc.cx(qr[0], qr[1]) +qc.measure(qr, cr) + +backend = service.least_busy(operational=True, simulator=False) +pm = generate_preset_pass_manager(target=backend.target, optimization_level=1) + +bell_isa_circuit = pm.run(qc) +psi_isa_circuit = pm.run(psi) +isa_observables = H1.apply_layout(psi_isa_circuit.layout) + +with Session(service=service, backend=backend) as session: + # Submit a request to the Sampler primitive within the session. + sampler = Sampler(session=session) + job = sampler.run([bell_isa_circuit]) + pub_result = job.result()[0] + print(f"Counts: {pub_result.data.cr.get_counts()}") + + # Submit a request to the Estimator primitive within the session. + estimator = Estimator(session=session) + estimator.options.resilience_level = 1 # Set options. + job = estimator.run( + [(psi_isa_circuit, isa_observables, theta)] + ) + pub_result = job.result()[0] + print(f"Expectation values: {pub_result.data.evs}") +``` + +## Local testing mode + +You can validate your quantum programs before sending them to a physical system using the local testing mode. The local testing mode is activated if one of the fake backends in `qiskit_ibm_runtime.fake_provider` or a Qiskit Aer backend instance is used when instantiating a primitive or a session. For example: + +```python +from qiskit_aer import AerSimulator +from qiskit.circuit.library import RealAmplitudes +from qiskit.circuit import QuantumCircuit, QuantumRegister, ClassicalRegister +from qiskit.quantum_info import SparsePauliOp +from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager + +from qiskit_ibm_runtime import Session +from qiskit_ibm_runtime import SamplerV2 as Sampler +from qiskit_ibm_runtime.fake_provider import FakeManilaV2 + +# Bell Circuit +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) +qc.measure_all() + +# Run the sampler job locally using FakeManilaV2 +fake_manila = FakeManilaV2() +pm = generate_preset_pass_manager(backend=fake_manila, optimization_level=1) +isa_qc = pm.run(qc) +sampler = Sampler(backend=fake_manila) +result = sampler.run([isa_qc]).result() + +# Run the sampler job locally using AerSimulator. +# Session syntax is supported but ignored. +aer_sim = AerSimulator() +pm = generate_preset_pass_manager(backend=aer_sim, optimization_level=1) +isa_qc = pm.run(qc) +with Session(backend=aer_sim) as session: + sampler = Sampler(session=session) + result = sampler.run([isa_qc]).result() +``` + +## Backend data + +[`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.QiskitRuntimeService") also has methods, such as `backend()`, `backends()`, and `least_busy()`, that allow you to query for a target backend to use. These methods return one or more [`IBMBackend`](qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.IBMBackend") instances that contains methods and attributes describing the backend. + +## Supplementary Information + +### Account initialization + +You need to initialize your account before you can start using the Qiskit Runtime service. This is done by initializing a [`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.QiskitRuntimeService") instance with your account credentials. If you don’t want to pass in the credentials each time, you can use the [`QiskitRuntimeService.save_account()`](qiskit_ibm_runtime.QiskitRuntimeService#save_account "qiskit_ibm_runtime.QiskitRuntimeService.save_account") method to save the credentials on disk. + +Qiskit Runtime is available on both IBM Cloud and IBM Quantum, and you can specify `channel="ibm_cloud"` for IBM Cloud and `channel="ibm_quantum"` for IBM Quantum. The default is IBM Cloud. + +### Runtime Jobs + +When you use the `run()` method of the [`Sampler`](qiskit_ibm_runtime.Sampler "qiskit_ibm_runtime.Sampler") or [`Estimator`](qiskit_ibm_runtime.Estimator "qiskit_ibm_runtime.Estimator") to invoke the primitive, a [`RuntimeJob`](qiskit_ibm_runtime.RuntimeJob "qiskit_ibm_runtime.RuntimeJob") instance is returned. This class has all the basic job methods, such as [`RuntimeJob.status()`](qiskit_ibm_runtime.RuntimeJob#status "qiskit_ibm_runtime.RuntimeJob.status"), [`RuntimeJob.result()`](qiskit_ibm_runtime.RuntimeJob#result "qiskit_ibm_runtime.RuntimeJob.result"), and [`RuntimeJob.cancel()`](qiskit_ibm_runtime.RuntimeJob#cancel "qiskit_ibm_runtime.RuntimeJob.cancel"). + +### Logging + +`qiskit-ibm-runtime` uses the `qiskit_ibm_runtime` logger. + +Two environment variables can be used to control the logging: + +> * **`QISKIT_IBM_RUNTIME_LOG_LEVEL`: Specifies the log level to use.** +> +> If an invalid level is set, the log level defaults to `WARNING`. The valid log levels are `DEBUG`, `INFO`, `WARNING`, `ERROR`, and `CRITICAL` (case-insensitive). If the environment variable is not set, then the parent logger’s level is used, which also defaults to `WARNING`. +> +> * **`QISKIT_IBM_RUNTIME_LOG_FILE`: Specifies the name of the log file to use. If specified,** +> +> messages will be logged to the file only. Otherwise messages will be logged to the standard error (usually the screen). + +For more advanced use, you can modify the logger itself. For example, to manually set the level to `WARNING`: + +```python +import logging +logging.getLogger('qiskit_ibm_runtime').setLevel(logging.WARNING) +``` + +## Classes + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | +| [`QiskitRuntimeService`](qiskit_ibm_runtime.QiskitRuntimeService "qiskit_ibm_runtime.QiskitRuntimeService")(\[channel, token, url, ...]) | Class for interacting with the Qiskit Runtime service. | +| [`Estimator`](qiskit_ibm_runtime.Estimator "qiskit_ibm_runtime.Estimator") | alias of [`EstimatorV2`](qiskit_ibm_runtime.EstimatorV2 "qiskit_ibm_runtime.estimator.EstimatorV2") | +| [`EstimatorV2`](qiskit_ibm_runtime.EstimatorV2 "qiskit_ibm_runtime.EstimatorV2")(\[mode, options]) | Class for interacting with Qiskit Runtime Estimator primitive service. | +| [`Sampler`](qiskit_ibm_runtime.Sampler "qiskit_ibm_runtime.Sampler") | alias of [`SamplerV2`](qiskit_ibm_runtime.SamplerV2 "qiskit_ibm_runtime.sampler.SamplerV2") | +| [`SamplerV2`](qiskit_ibm_runtime.SamplerV2 "qiskit_ibm_runtime.SamplerV2")(\[mode, options]) | Class for interacting with Qiskit Runtime Sampler primitive service. | +| [`Session`](qiskit_ibm_runtime.Session "qiskit_ibm_runtime.Session")(\[service, backend, max\_time]) | Class for creating a Qiskit Runtime session. | +| [`Batch`](qiskit_ibm_runtime.Batch "qiskit_ibm_runtime.Batch")(\[service, backend, max\_time]) | Class for running jobs in batch execution mode. | +| [`IBMBackend`](qiskit_ibm_runtime.IBMBackend "qiskit_ibm_runtime.IBMBackend")(configuration, service, api\_client) | Backend class interfacing with an IBM Quantum backend. | +| [`RuntimeJob`](qiskit_ibm_runtime.RuntimeJob "qiskit_ibm_runtime.RuntimeJob")(backend, api\_client, ...\[, ...]) | Representation of a runtime primitive execution. | +| [`RuntimeJobV2`](qiskit_ibm_runtime.RuntimeJobV2 "qiskit_ibm_runtime.RuntimeJobV2")(backend, api\_client, ...\[, ...]) | Representation of a runtime V2 primitive exeuction. | +| [`RuntimeEncoder`](qiskit_ibm_runtime.RuntimeEncoder "qiskit_ibm_runtime.RuntimeEncoder")(\*\[, skipkeys, ensure\_ascii, ...]) | JSON Encoder used by runtime service. | +| [`RuntimeDecoder`](qiskit_ibm_runtime.RuntimeDecoder "qiskit_ibm_runtime.RuntimeDecoder")(\*args, \*\*kwargs) | JSON Decoder used by runtime service. | + diff --git a/docs/api/qiskit-ibm-runtime/0.31/transpiler.mdx b/docs/api/qiskit-ibm-runtime/0.31/transpiler.mdx new file mode 100644 index 00000000000..51eda4fd58d --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/transpiler.mdx @@ -0,0 +1,25 @@ +--- +title: passes +description: API reference for qiskit_ibm_runtime.transpiler.passes +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.transpiler.passes +--- + + + + + +# Transpiler passes + +`qiskit_ibm_runtime.transpiler.passes` + +A collection of transpiler passes. Refer to [guides/transpile](/guides/transpile) to learn more about transpilation and passes. + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------- | +| [`ConvertIdToDelay`](qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay "qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay")(durations\[, gate]) | Convert `qiskit.circuit.library.standard_gates.IGate` to a delay of the corresponding length. | +| [`ConvertISAToClifford`](qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford "qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford")(\*args, \*\*kwargs) | Convert the gates of an ISA circuit to Clifford gates. | + +See [`qiskit_ibm_runtime.transpiler.passes.scheduling`](qiskit_ibm_runtime.transpiler.passes.scheduling#module-qiskit_ibm_runtime.transpiler.passes.scheduling "qiskit_ibm_runtime.transpiler.passes.scheduling") for a collection of scheduling passes. + diff --git a/docs/api/qiskit-ibm-runtime/0.31/visualization.mdx b/docs/api/qiskit-ibm-runtime/0.31/visualization.mdx new file mode 100644 index 00000000000..25faf46d415 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/0.31/visualization.mdx @@ -0,0 +1,24 @@ +--- +title: visualization +description: API reference for qiskit_ibm_runtime.visualization +in_page_toc_min_heading_level: 2 +python_api_type: module +python_api_name: qiskit_ibm_runtime.visualization +--- + + + + + +# Visualization + +`qiskit_ibm_runtime.visualization` + +A suite of functions for visualizing qiskit-ibm-runtime’s objects. + +## Functions + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`draw_layer_error_map`](qiskit_ibm_runtime.visualization.draw_layer_error_map "qiskit_ibm_runtime.visualization.draw_layer_error_map")(layer\_error, embedding) | Draw a map view of a [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError"). | + diff --git a/docs/api/qiskit-ibm-runtime/_package.json b/docs/api/qiskit-ibm-runtime/_package.json index becbcc5520c..3fba361ca7f 100644 --- a/docs/api/qiskit-ibm-runtime/_package.json +++ b/docs/api/qiskit-ibm-runtime/_package.json @@ -1,4 +1,4 @@ { "name": "qiskit-ibm-runtime", - "version": "0.31.0" + "version": "0.32.0" } diff --git a/docs/api/qiskit-ibm-runtime/_toc.json b/docs/api/qiskit-ibm-runtime/_toc.json index 3eed46cb896..3c9aea17d9e 100644 --- a/docs/api/qiskit-ibm-runtime/_toc.json +++ b/docs/api/qiskit-ibm-runtime/_toc.json @@ -90,6 +90,10 @@ "title": "Module overview", "url": "/api/qiskit-ibm-runtime/execution_span" }, + { + "title": "DoubleSliceSpan", + "url": "/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.DoubleSliceSpan" + }, { "title": "ExecutionSpan", "url": "/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpan" @@ -501,6 +505,10 @@ "title": "Module overview", "url": "/api/qiskit-ibm-runtime/visualization" }, + { + "title": "draw_execution_spans", + "url": "/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_execution_spans" + }, { "title": "draw_layer_error_map", "url": "/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_layer_error_map" diff --git a/docs/api/qiskit-ibm-runtime/dev/_package.json b/docs/api/qiskit-ibm-runtime/dev/_package.json index 85ad945d4b2..c6e2fc87eee 100644 --- a/docs/api/qiskit-ibm-runtime/dev/_package.json +++ b/docs/api/qiskit-ibm-runtime/dev/_package.json @@ -1,4 +1,4 @@ { "name": "qiskit-ibm-runtime", - "version": "0.32.0-dev" + "version": "0.33.0-dev" } diff --git a/docs/api/qiskit-ibm-runtime/dev/_toc.json b/docs/api/qiskit-ibm-runtime/dev/_toc.json index c9033005ab9..8af1c7ff65f 100644 --- a/docs/api/qiskit-ibm-runtime/dev/_toc.json +++ b/docs/api/qiskit-ibm-runtime/dev/_toc.json @@ -90,6 +90,10 @@ "title": "Module overview", "url": "/api/qiskit-ibm-runtime/dev/execution_span" }, + { + "title": "DoubleSliceSpan", + "url": "/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.DoubleSliceSpan" + }, { "title": "ExecutionSpan", "url": "/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.ExecutionSpan" @@ -501,6 +505,10 @@ "title": "Module overview", "url": "/api/qiskit-ibm-runtime/dev/visualization" }, + { + "title": "draw_execution_spans", + "url": "/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_execution_spans" + }, { "title": "draw_layer_error_map", "url": "/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_layer_error_map" diff --git a/docs/api/qiskit-ibm-runtime/dev/execution_span.mdx b/docs/api/qiskit-ibm-runtime/dev/execution_span.mdx index 9d0cf9f8970..6f3ce48bde1 100644 --- a/docs/api/qiskit-ibm-runtime/dev/execution_span.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/execution_span.mdx @@ -20,10 +20,11 @@ An [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_i ## Classes -| | | -| ----------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")(start, stop) | Abstract parent for classes that store an execution time span for a subset of job data. | -| [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans")(spans) | A collection of timings for pub results. | -| [`ShapeType`](qiskit_ibm_runtime.execution_span.ShapeType "qiskit_ibm_runtime.execution_span.ShapeType") | alias of `Tuple`\[`int`, ...] | -| [`SliceSpan`](qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan")(start, stop, data\_slices) | An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. | +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`DoubleSliceSpan`](qiskit_ibm_runtime.execution_span.DoubleSliceSpan "qiskit_ibm_runtime.execution_span.DoubleSliceSpan")(start, stop, data\_slices) | An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. | +| [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")(start, stop) | Abstract parent for classes that store an execution time span for a subset of job data. | +| [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans")(spans) | A collection of timings for pub results. | +| [`ShapeType`](qiskit_ibm_runtime.execution_span.ShapeType "qiskit_ibm_runtime.execution_span.ShapeType") | alias of `Tuple`\[`int`, ...] | +| [`SliceSpan`](qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan")(start, stop, data\_slices) | An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. | diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.Estimator.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.Estimator.mdx index adcff6a2993..685a8827417 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.Estimator.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.Estimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.Estimator # Estimator - + alias of [`EstimatorV2`](qiskit_ibm_runtime.EstimatorV2 "qiskit_ibm_runtime.estimator.EstimatorV2") diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.EstimatorV2.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.EstimatorV2.mdx index aed60da8c32..08c6f91859f 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.EstimatorV2.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.EstimatorV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.EstimatorV2 # EstimatorV2 - + Class for interacting with Qiskit Runtime Estimator primitive service. Qiskit Runtime Estimator primitive service estimates expectation values of quantum circuits and observables. @@ -97,6 +97,16 @@ python_api_name: qiskit_ibm_runtime.EstimatorV2 ## Methods + ### backend + + + Return the backend the primitive query will be run on. + + **Return type** + + BackendV1 | BackendV2 + + ### run diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.IBMBackend.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.IBMBackend.mdx index 740ed6b7de4..14359853c99 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.IBMBackend.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.IBMBackend.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend # IBMBackend - + Backend class interfacing with an IBM Quantum backend. @@ -343,7 +343,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### \_\_call\_\_ - + Call self as a function. **Return type** @@ -353,7 +353,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### acquire\_channel - + Return the acquisition channel for the given qubit. **Returns** @@ -367,7 +367,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### cancel\_session - + Cancel session. All pending jobs will be cancelled. **Return type** @@ -377,7 +377,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -395,7 +395,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### close\_session - + Close the session so new jobs will no longer be accepted, but existing queued or running jobs will run to completion. The session will be terminated once there are no more pending jobs. **Return type** @@ -405,7 +405,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### configuration - + Return the backend configuration. Backend configuration contains fixed information about the backend, such as its name, number of qubits, basis gates, coupling map, quantum volume, etc. @@ -435,7 +435,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -455,7 +455,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### defaults - + Return the pulse defaults for the backend. The schema for default pulse configuration can be found in [Qiskit/ibm-quantum-schemas/default\_pulse\_configuration](https://github.com/Qiskit/ibm-quantum-schemas/blob/main/schemas/default_pulse_configuration_schema.json). @@ -475,7 +475,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### drive\_channel - + Return the drive channel for the given qubit. **Returns** @@ -489,7 +489,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### get\_translation\_stage\_plugin - + Return the default translation stage plugin name for IBM backends. **Return type** @@ -499,7 +499,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### measure\_channel - + Return the measure stimulus channel for the given qubit. **Returns** @@ -513,7 +513,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### open\_session - + Open session **Return type** @@ -523,7 +523,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### properties - + Return the backend properties, subject to optional filtering. This data describes qubits properties (such as T1 and T2), gates properties (such as gate length and error), and other general properties of the backend. @@ -573,9 +573,19 @@ python_api_name: qiskit_ibm_runtime.IBMBackend **NotImplementedError** – if the backend doesn’t support querying the qubit properties + ### refresh + + + Retrieve the newest backend configuration and refresh the current backend target. + + **Return type** + + `None` + + ### run - + Run on the backend. If a keyword specified here is also present in the `options` attribute/object, the value specified here will be used for this run. **Parameters** @@ -664,7 +674,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### status - + Return the backend status. @@ -686,7 +696,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### target\_history - + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeDecoder.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeDecoder.mdx index 5e9bade5953..0e7e10a79fc 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeDecoder.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeDecoder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeDecoder # RuntimeDecoder - + JSON Decoder used by runtime service. `object_hook`, if specified, will be called with the result of every JSON object decoded and its return value will be used in place of the given `dict`. This can be used to provide custom deserializations (e.g. to support JSON-RPC class hinting). @@ -33,7 +33,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeDecoder ### object\_hook - + Called to decode object. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeEncoder.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeEncoder.mdx index e656717827e..7f703310b5e 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeEncoder.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeEncoder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeEncoder # RuntimeEncoder - + JSON Encoder used by runtime service. Constructor for JSONEncoder, with sensible defaults. @@ -43,7 +43,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeEncoder ### default - + Implement this method in a subclass such that it returns a serializable object for `o`, or calls the base implementation (to raise a `TypeError`). For example, to support arbitrary iterators, you could implement default like this: diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJob.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJob.mdx index ffd1f3aaf1d..85ce97942d9 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJob.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob # RuntimeJob - + Representation of a runtime primitive execution. A new `RuntimeJob` instance is returned when you call `QiskitRuntimeService.run` to execute a runtime primitive, or [`QiskitRuntimeService.job`](qiskit_ibm_runtime.QiskitRuntimeService#job "qiskit_ibm_runtime.QiskitRuntimeService.job") to retrieve a previously executed job. @@ -27,7 +27,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob print("Job failed!: {}".format(ex)) ``` - If the primitive has any interim results, you can use the `callback` parameter of the `run()` method to stream the interim results along with the final result. Alternatively, you can use the [`stream_results()`](#qiskit_ibm_runtime.RuntimeJob.stream_results "qiskit_ibm_runtime.RuntimeJob.stream_results") method to stream the results at a later time, but before the job finishes. + If the primitive has any interim results, you can use the `callback` parameter of the `run()` method to stream the interim results along with the final result. Alternatively, you can use the `stream_results()` method to stream the results at a later time, but before the job finishes. RuntimeJob constructor. @@ -256,28 +256,6 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob `bool` - ### interim\_results - - - (DEPRECATED) Return the interim results of the job. - - **Parameters** - - **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode interim results. - - **Return type** - - `Any` - - **Returns** - - Runtime job interim results. - - **Raises** - - **RuntimeJobFailureError** – If the job failed. - - ### job\_id @@ -441,31 +419,6 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob Status of this job. - ### stream\_results - - - (DEPRECATED) Start streaming job results. - - **Parameters** - - * **callback** (`Callable`) – - - Callback function to be invoked for any interim results and final result. The callback function will receive 2 positional parameters: - - > 1. Job ID - > 2. Job result. - - * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. - - **Raises** - - **RuntimeInvalidStateError** – If a callback function is already streaming results or if the job already finished. - - **Return type** - - `None` - - ### submit diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJobV2.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJobV2.mdx index ba4430c0ead..5250e83f9c1 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJobV2.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.RuntimeJobV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 # RuntimeJobV2 - + Representation of a runtime V2 primitive exeuction. RuntimeJob constructor. @@ -234,28 +234,6 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 `bool` - ### interim\_results - - - (DEPRECATED) Return the interim results of the job. - - **Parameters** - - **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode interim results. - - **Return type** - - `Any` - - **Returns** - - Runtime job interim results. - - **Raises** - - **RuntimeJobFailureError** – If the job failed. - - ### job\_id @@ -377,31 +355,6 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 Status of this job. - ### stream\_results - - - (DEPRECATED) Start streaming job results. - - **Parameters** - - * **callback** (`Callable`) – - - Callback function to be invoked for any interim results and final result. The callback function will receive 2 positional parameters: - - > 1. Job ID - > 2. Job result. - - * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. - - **Raises** - - **RuntimeInvalidStateError** – If a callback function is already streaming results or if the job already finished. - - **Return type** - - `None` - - ### update\_tags diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.SamplerV2.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.SamplerV2.mdx index ee08e49434a..801bad97ba4 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.SamplerV2.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.SamplerV2.mdx @@ -65,6 +65,16 @@ python_api_name: qiskit_ibm_runtime.SamplerV2 ## Methods + ### backend + + + Return the backend the primitive query will be run on. + + **Return type** + + BackendV1 | BackendV2 + + ### run diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx new file mode 100644 index 00000000000..8bbc2273314 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx @@ -0,0 +1,128 @@ +--- +title: DoubleSliceSpan +description: API reference for qiskit_ibm_runtime.execution_span.DoubleSliceSpan +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.execution_span.DoubleSliceSpan +--- + +# DoubleSliceSpan + + + An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. + + This type of execution span references pub result data by assuming that it is a sliceable portion of the data where the shots are the outermost slice and the rest of the data is flattened. Therefore, for each pub dependent on this span, the constructor accepts two `slice` objects, along with the corresponding shape of the data to be sliced; in contrast to [`SliceSpan`](qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan"), this class does not assume that *all* shots for a particular set of parameter values are contiguous in the array of data. + + **Parameters** + + * **start** (`datetime`) – The start time of the span, in UTC. + * **stop** (`datetime`) – The stop time of the span, in UTC. + * **data\_slices** (`dict`\[`int`, `tuple`\[`Tuple`\[`int`, `...`], `slice`, `slice`]]) – A map from pub indices to `(shape_tuple, slice, slice)`. + + ## Attributes + + ### duration + + + The duration of this span, in seconds. + + **Return type** + + `float` + + + ### pub\_idxs + + + **Return type** + + `list`\[`int`] + + + ### size + + + **Return type** + + `int` + + + ### start + + + The start time of the span, in UTC. + + **Return type** + + `datetime` + + + ### stop + + + The stop time of the span, in UTC. + + **Return type** + + `datetime` + + + ## Methods + + ### contains\_pub + + + Return whether the pub with the given index has data with dependence on this span. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + bool + + **Returns** + + Whether there is dependence on this span. + + + ### filter\_by\_pub + + + Return a new span whose slices are filtered to the provided pub indices. + + For example, if this span contains slice information for pubs with indices 1, 3, 4 and `[1, 4]` is provided, then the span returned by this method will contain slice information for only those two indices, but be identical otherwise. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + [DoubleSliceSpan](#qiskit_ibm_runtime.execution_span.DoubleSliceSpan "qiskit_ibm_runtime.execution_span.DoubleSliceSpan") + + **Returns** + + A new filtered span. + + + ### mask + + + Return an array-valued mask specifying which parts of a pub result depend on this span. + + **Parameters** + + **pub\_idx** (`int`) – The index of the pub to return a mask for. + + **Return type** + + [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v2.1)")\[`Any`, [`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[[`bool`](https://numpy.org/doc/stable/reference/arrays.scalars.html#numpy.bool "(in NumPy v2.1)")]] + + **Returns** + + An array with the same shape as the pub data. + + + diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx index a660abf081a..250fa1a6386 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans # ExecutionSpans - + A collection of timings for pub results. This class is a list-like containing [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")s, where each execution span represents a time window of data collection, and contains a reference to exactly which of the data were collected during the window. @@ -61,7 +61,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans ### \_\_getitem\_\_ - + **Return type** [ExecutionSpan](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") | ‘ExecutionSpans @@ -69,15 +69,39 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans ### \_\_len\_\_ - + **Return type** `int` + ### draw + + + Draw these execution spans. + + + To draw multiple sets of execution spans at once, for example coming from multiple jobs, consider calling [`draw_execution_spans()`](qiskit_ibm_runtime.visualization.draw_execution_spans "qiskit_ibm_runtime.visualization.draw_execution_spans") directly. + + + **Parameters** + + * **name** (`Optional`\[`str`]) – The name of this set of spans. + * **normalize\_y** (`bool`) – Whether to display the y-axis units as a percentage of work complete, rather than cumulative shots completed. + * **line\_width** (`int`) – The thickness of line segments. + + **Return type** + + `Figure` + + **Returns** + + A plotly figure. + + ### filter\_by\_pub - + Return a new set of spans where each one has been filtered to the specified pubs. See also :meth:\~.ExecutionSpan.filter\_by\_pub\`. @@ -93,7 +117,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans ### sort - + Return the same execution spans, sorted. Sorting is done by the [`start`](qiskit_ibm_runtime.execution_span.ExecutionSpan#start "qiskit_ibm_runtime.execution_span.ExecutionSpan.start") timestamp of each execution span. diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx index f58ee995ea9..897c6b417d4 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.noise_learner.NoiseLearner # NoiseLearner - + Class for executing noise learning experiments. @@ -73,7 +73,7 @@ python_api_name: qiskit_ibm_runtime.noise_learner.NoiseLearner **References** - 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages 1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) ## Attributes @@ -89,6 +89,16 @@ python_api_name: qiskit_ibm_runtime.noise_learner.NoiseLearner ## Methods + ### backend + + + Return the backend the primitive query will be run on. + + **Return type** + + [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)") + + ### run diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.EstimatorOptions.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.EstimatorOptions.mdx index b84bf338c86..7641c4b9a0a 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.EstimatorOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.EstimatorOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.EstimatorOptions # EstimatorOptions - + Options for V2 Estimator. ## Attributes @@ -63,17 +63,6 @@ python_api_name: qiskit_ibm_runtime.options.EstimatorOptions - ### optimization\_level - - - (DEPRECATED) How much optimization to perform on the circuits. Higher levels generate more optimized circuits, at the expense of longer processing times. - - * 0: no optimization - * 1: light optimization - - Default: 0. - - ### resilience diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx index 02412c1e3df..c425da072e8 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx @@ -8,13 +8,23 @@ python_api_name: qiskit_ibm_runtime.options.LayerNoiseLearningOptions # LayerNoiseLearningOptions - + Options for learning layer noise. This is only used by V2 Estimator. These options are only used when the resilience level or options specify a technique that requires layer noise learning. + + The total number of unique circuits implemented to learn the noise of a single layer depends solely on [`layer_pair_depths`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.layer_pair_depths "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.layer_pair_depths") and [`num_randomizations`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.num_randomizations "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.num_randomizations"). For example, if `layer_pair_depths` contains six depths and `num_randomizations` is set to `32`, the noise learning stage executes a total of `6 * 9` unique circuits per layer, each one with `32` randomizations (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization") each). + + The number `9` above is the number of unique circuits that need to be implemented to learn the noise for all the two-qubit subsystem in the given layer by performing local measurements. Indeed, learning the noise for a single one of these subsystems requires measuring all the `16` two-qubit Paulis on that subsystem. Taking advantage of commutation relations to measure more than one of these Paulis (for example, `XI`, `IX`, and `XX`) with a single circuit, it is possible to measure all these `16` Paulis by implementing only `9` circuits. Parallelizing these measurement tasks in the optimal way allows then measuring the `16` Paulis for all of the layer’s two-qubit subsystems with only `9` circuits. More details in Ref. \[1]. + + + **References** + + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages 1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + ## Attributes ### layer\_pair\_depths @@ -36,7 +46,7 @@ python_api_name: qiskit_ibm_runtime.options.LayerNoiseLearningOptions ### num\_randomizations - The number of random circuits to use per learning circuit configuration. A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, and nine required measurement bases, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization") each). + The number of random circuits to use per learning circuit configuration. A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (where `9` is the number of circuits that need to be implemented to measure all the required observables, see the note in the docstring for [`LayerNoiseLearningOptions`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions "qiskit_ibm_runtime.options.LayerNoiseLearningOptions") for mode details), at [`shots_per_randomization`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization") each. Default: 32. diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx index 5ac19ec8a47..235068acef7 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx @@ -8,9 +8,19 @@ python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions # NoiseLearnerOptions - + Options for [`NoiseLearner`](qiskit_ibm_runtime.noise_learner.NoiseLearner "qiskit_ibm_runtime.noise_learner.NoiseLearner"). + + The total number of unique circuits implemented to learn the noise of a single layer depends solely on [`layer_pair_depths`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.layer_pair_depths "qiskit_ibm_runtime.options.NoiseLearnerOptions.layer_pair_depths") and [`num_randomizations`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.num_randomizations "qiskit_ibm_runtime.options.NoiseLearnerOptions.num_randomizations"). For example, if `layer_pair_depths` contains six depths and `num_randomizations` is set to `32`, the noise learning stage executes a total of `6 * 9` unique circuits per layer, each one with `32` randomizations (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization "qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization") each). + + The number `9` above is the number of unique circuits that need to be implemented to learn the noise for all the two-qubit subsystem in the given layer by performing local measurements. Indeed, learning the noise for a single one of these subsystems requires measuring all the `16` two-qubit Paulis on that subsystem. Taking advantage of commutation relations to measure more than one of these Paulis (for example, `XI`, `IX`, and `XX`) with a single circuit, it is possible to measure all these `16` Paulis by implementing only `9` circuits. Parallelizing these measurement tasks in the optimal way allows then measuring the `16` Paulis for all of the layer’s two-qubit subsystems with only `9` circuits. More details in Ref. \[1]. + + + **References** + + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages 1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + ## Attributes ### environment @@ -30,7 +40,7 @@ python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions The circuit depths (measured in number of pairs) to use in learning experiments. - Pairs are used as the unit because we exploit the order-2 nature of our entangling gates in the noise learning implementation. A value of `3` would correspond to 6 layers of the layer of interest, for example. Default: (0, 1, 2, 4, 16, 32). + Pairs are used as the unit because we exploit the order-2 nature of our entangling gates in the noise learning implementation. For example, a value of `3` corresponds to 6 repetitions of the layer of interest. Default: (0, 1, 2, 4, 16, 32). ### max\_execution\_time @@ -50,7 +60,7 @@ python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions The number of random circuits to use per learning circuit configuration. - A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, and nine required measurement bases, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization "qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization") each). Default: 32. + A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (where `9` is the number of circuits that need to be implemented to measure all the required observables, see the note in the docstring for [`NoiseLearnerOptions`](#qiskit_ibm_runtime.options.NoiseLearnerOptions "qiskit_ibm_runtime.options.NoiseLearnerOptions") for mode details), at [`shots_per_randomization`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization "qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization") each. ### shots\_per\_randomization diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.ZneOptions.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.ZneOptions.mdx index 178693d70fa..e91489d97ab 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.ZneOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.options.ZneOptions.mdx @@ -22,7 +22,7 @@ python_api_name: qiskit_ibm_runtime.options.ZneOptions 2. `pub_result.data.evs_noise_factors`, `pub_result.data.stds_noise_factors`, and `ensemble_stds_noise_factors` all have shape `(*shape, num_noise_factors)` where `num_noise_factors` is the length of `options.resilience.zne.noise_factors`. These values provide evaluations of the best-fit model at each of the noise amplifications. In the case of no twirling, both `*stds*` arrays will be equal, otherwise, `stds_noise_factors` is derived from the spread over twirling samples, whereas `ensemble_stds_noise_factors` assumes only shot noise and no drift. - Technical note: for single observables with multiple basis terms it might turn out that multiple extrapolation methods are used in *the same* expectation value, for example, `XX` gets linearly extrapolated but `XY` gets exponentially extrapolated in the observable `{"XX": 0.5, "XY": 0.5}`. Let’s call this a *hetergeneous fit*. The data from (2) is evaluated from heterogeneous fits by selecting the best fit for every individual distinct term, whereas data from (1) is evaluated from forced homogenous fits, one for each provided extrapolator. If your work requires a nuanced distinction in this regard, we presently recommend that you use single-term observables in addition to your multi-term observables. + Technical note: for single observables with multiple basis terms it might turn out that multiple extrapolation methods are used in *the same* expectation value, for example, `XX` gets linearly extrapolated but `XY` gets exponentially extrapolated in the observable `{"XX": 0.5, "XY": 0.5}`. Let’s call this a *heterogeneous fit*. The data from (2) is evaluated from heterogeneous fits by selecting the best fit for every individual distinct term, whereas data from (1) is evaluated from forced homogenous fits, one for each provided extrapolator. If your work requires a nuanced distinction in this regard, we presently recommend that you use single-term observables in addition to your multi-term observables. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx new file mode 100644 index 00000000000..383a364923c --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx @@ -0,0 +1,33 @@ +--- +title: draw_execution_spans +description: API reference for qiskit_ibm_runtime.visualization.draw_execution_spans +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit_ibm_runtime.visualization.draw_execution_spans +--- + + + +# draw\_execution\_spans + + + Draw one or more [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans") on a bar plot. + + **Parameters** + + * **spans** ([*ExecutionSpans*](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans")) – One or more [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans"). + * **names** (*str | Iterable\[str] | None*) – Name or names to assign to respective `spans`. + * **common\_start** (*bool*) – Whether to shift all collections of spans so that their first span’s start is at $t=0$. + * **normalize\_y** (*bool*) – Whether to display the y-axis units as a percentage of work complete, rather than cumulative shots completed. + * **line\_width** (*int*) – The thickness of line segments. + * **show\_legend** (*bool*) – Whether to show a legend. By default, this choice is automatic. + + **Return type** + + PlotlyFigure + + **Returns** + + A plotly figure. + + diff --git a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx index 1ed7b7ddc88..91a37007fd0 100644 --- a/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit_ibm_runtime.visualization.draw_layer_error_map # draw\_layer\_error\_map - + Draw a map view of a [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError"). **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/dev/visualization.mdx b/docs/api/qiskit-ibm-runtime/dev/visualization.mdx index 25faf46d415..e1f16ffd8ce 100644 --- a/docs/api/qiskit-ibm-runtime/dev/visualization.mdx +++ b/docs/api/qiskit-ibm-runtime/dev/visualization.mdx @@ -20,5 +20,6 @@ A suite of functions for visualizing qiskit-ibm-runtime’s objects. | | | | ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`draw_execution_spans`](qiskit_ibm_runtime.visualization.draw_execution_spans "qiskit_ibm_runtime.visualization.draw_execution_spans")(\*spans\[, names, ...]) | Draw one or more [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans") on a bar plot. | | [`draw_layer_error_map`](qiskit_ibm_runtime.visualization.draw_layer_error_map "qiskit_ibm_runtime.visualization.draw_layer_error_map")(layer\_error, embedding) | Draw a map view of a [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError"). | diff --git a/docs/api/qiskit-ibm-runtime/execution_span.mdx b/docs/api/qiskit-ibm-runtime/execution_span.mdx index 9d0cf9f8970..6f3ce48bde1 100644 --- a/docs/api/qiskit-ibm-runtime/execution_span.mdx +++ b/docs/api/qiskit-ibm-runtime/execution_span.mdx @@ -20,10 +20,11 @@ An [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_i ## Classes -| | | -| ----------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")(start, stop) | Abstract parent for classes that store an execution time span for a subset of job data. | -| [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans")(spans) | A collection of timings for pub results. | -| [`ShapeType`](qiskit_ibm_runtime.execution_span.ShapeType "qiskit_ibm_runtime.execution_span.ShapeType") | alias of `Tuple`\[`int`, ...] | -| [`SliceSpan`](qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan")(start, stop, data\_slices) | An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. | +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`DoubleSliceSpan`](qiskit_ibm_runtime.execution_span.DoubleSliceSpan "qiskit_ibm_runtime.execution_span.DoubleSliceSpan")(start, stop, data\_slices) | An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. | +| [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")(start, stop) | Abstract parent for classes that store an execution time span for a subset of job data. | +| [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans")(spans) | A collection of timings for pub results. | +| [`ShapeType`](qiskit_ibm_runtime.execution_span.ShapeType "qiskit_ibm_runtime.execution_span.ShapeType") | alias of `Tuple`\[`int`, ...] | +| [`SliceSpan`](qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan")(start, stop, data\_slices) | An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. | diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Batch.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Batch.mdx index 99cc487da48..5cb5926d950 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Batch.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Batch.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.Batch # Batch - + Class for running jobs in batch execution mode. The `batch` mode is designed to efficiently perform experiments that comprise multiple independent jobs. @@ -108,7 +108,7 @@ python_api_name: qiskit_ibm_runtime.Batch ### backend - + Return backend for this session. **Return type** @@ -122,7 +122,7 @@ python_api_name: qiskit_ibm_runtime.Batch ### cancel - + Cancel all pending jobs in a session. **Return type** @@ -132,7 +132,7 @@ python_api_name: qiskit_ibm_runtime.Batch ### close - + Close the session so new jobs will no longer be accepted, but existing queued or running jobs will run to completion. The session will be terminated once there are no more pending jobs. **Return type** @@ -142,7 +142,7 @@ python_api_name: qiskit_ibm_runtime.Batch ### details - + Return session details. **Return type** @@ -171,7 +171,7 @@ python_api_name: qiskit_ibm_runtime.Batch ### from\_id - + Construct a Session object with a given session\_id **Parameters** @@ -197,7 +197,7 @@ python_api_name: qiskit_ibm_runtime.Batch ### status - + Return current session status. **Return type** @@ -217,7 +217,7 @@ python_api_name: qiskit_ibm_runtime.Batch ### usage - + Return session usage in seconds. Session usage is the time from when the first job starts until the session goes inactive, is closed, or when its last job completes, whichever happens last. diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator.mdx index 0ff89fcbd70..7c37e2a83e4 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.Estimator # Estimator - + alias of [`EstimatorV2`](qiskit_ibm_runtime.EstimatorV2 "qiskit_ibm_runtime.estimator.EstimatorV2") diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.EstimatorV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.EstimatorV2.mdx index 997a7f76fcd..ccb122a84df 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.EstimatorV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.EstimatorV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.EstimatorV2 # EstimatorV2 - + Class for interacting with Qiskit Runtime Estimator primitive service. Qiskit Runtime Estimator primitive service estimates expectation values of quantum circuits and observables. @@ -65,10 +65,6 @@ python_api_name: qiskit_ibm_runtime.EstimatorV2 * **options** (`Union`\[`Dict`, [`EstimatorOptions`](qiskit_ibm_runtime.options.EstimatorOptions "qiskit_ibm_runtime.options.estimator_options.EstimatorOptions"), `None`]) – Estimator options, see `EstimatorOptions` for detailed description. - **Raises** - - **NotImplementedError** – If “q-ctrl” channel strategy is used. - ## Attributes ### mode @@ -101,9 +97,19 @@ python_api_name: qiskit_ibm_runtime.EstimatorV2 ## Methods + ### backend + + + Return the backend the primitive query will be run on. + + **Return type** + + BackendV1 | BackendV2 + + ### run - + Submit a request to the estimator primitive. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend.mdx index 25ce5498e74..ef0722e1e82 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend # IBMBackend - + Backend class interfacing with an IBM Quantum backend. @@ -343,7 +343,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### \_\_call\_\_ - + Call self as a function. **Return type** @@ -353,7 +353,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### acquire\_channel - + Return the acquisition channel for the given qubit. **Returns** @@ -367,7 +367,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### cancel\_session - + Cancel session. All pending jobs will be cancelled. **Return type** @@ -377,7 +377,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -395,7 +395,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### close\_session - + Close the session so new jobs will no longer be accepted, but existing queued or running jobs will run to completion. The session will be terminated once there are no more pending jobs. **Return type** @@ -405,7 +405,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### configuration - + Return the backend configuration. Backend configuration contains fixed information about the backend, such as its name, number of qubits, basis gates, coupling map, quantum volume, etc. @@ -435,7 +435,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -455,7 +455,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### defaults - + Return the pulse defaults for the backend. The schema for default pulse configuration can be found in [Qiskit/ibm-quantum-schemas/default\_pulse\_configuration](https://github.com/Qiskit/ibm-quantum-schemas/blob/main/schemas/default_pulse_configuration_schema.json). @@ -475,7 +475,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### drive\_channel - + Return the drive channel for the given qubit. **Returns** @@ -489,7 +489,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### get\_translation\_stage\_plugin - + Return the default translation stage plugin name for IBM backends. **Return type** @@ -499,7 +499,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### measure\_channel - + Return the measure stimulus channel for the given qubit. **Returns** @@ -513,7 +513,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### open\_session - + Open session **Return type** @@ -523,7 +523,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### properties - + Return the backend properties, subject to optional filtering. This data describes qubits properties (such as T1 and T2), gates properties (such as gate length and error), and other general properties of the backend. @@ -573,9 +573,19 @@ python_api_name: qiskit_ibm_runtime.IBMBackend **NotImplementedError** – if the backend doesn’t support querying the qubit properties + ### refresh + + + Retrieve the newest backend configuration and refresh the current backend target. + + **Return type** + + `None` + + ### run - + Run on the backend. If a keyword specified here is also present in the `options` attribute/object, the value specified here will be used for this run. **Parameters** @@ -664,7 +674,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### status - + Return the backend status. @@ -686,7 +696,7 @@ python_api_name: qiskit_ibm_runtime.IBMBackend ### target\_history - + A [`qiskit.transpiler.Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") object for the backend. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService.mdx index 454df61c788..06f5c79eb14 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService # QiskitRuntimeService - + Class for interacting with the Qiskit Runtime service. QiskitRuntimeService constructor @@ -35,7 +35,6 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService * **instance** (`Optional`\[`str`]) – The service instance to use. For `ibm_cloud` runtime, this is the Cloud Resource Name (CRN) or the service name. For `ibm_quantum` runtime, this is the hub/group/project in that format. * **proxies** (`Optional`\[`dict`]) – Proxy configuration. Supported optional keys are `urls` (a dictionary mapping protocol or protocol and host to the URL of the proxy, documented at [https://docs.python-requests.org/en/latest/api/#requests.Session.proxies](https://docs.python-requests.org/en/latest/api/#requests.Session.proxies)), `username_ntlm`, `password_ntlm` (username and password to enable NTLM user authentication) * **verify** (`Optional`\[`bool`]) – Whether to verify the server’s TLS certificate. - * **channel\_strategy** (`Optional`\[`str`]) – (DEPRECATED) Error mitigation strategy. * **private\_endpoint** (`Optional`\[`bool`]) – Connect to private API URL. * **url\_resolver** (`Optional`\[`Callable`\[\[`str`, `str`, `Optional`\[`bool`]], `str`]]) – Function used to resolve the runtime url. @@ -71,7 +70,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### active\_account - + Return the IBM Quantum account currently in use for the session. **Return type** @@ -85,7 +84,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### backend - + Return a single backend matching the specified filtering. **Parameters** @@ -109,7 +108,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### backends - + Return all backends accessible via this account, subject to optional filtering. **Parameters** @@ -170,7 +169,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### check\_pending\_jobs - + Check the number of pending jobs and wait for the oldest pending job if the maximum number of pending jobs has been reached. **Return type** @@ -180,7 +179,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### delete\_account - + Delete a saved account from disk. **Parameters** @@ -200,7 +199,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### delete\_job - + Delete a runtime job. Note that this operation cannot be reversed. @@ -221,7 +220,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### instances - + Return the IBM Quantum instances list currently in use for the session. **Return type** @@ -235,7 +234,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### job - + Retrieve a runtime job. **Parameters** @@ -258,7 +257,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### jobs - + Retrieve all runtime jobs, subject to optional filtering. **Parameters** @@ -290,7 +289,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### least\_busy - + Return the least busy available backend. **Parameters** @@ -322,7 +321,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### save\_account - + Save the account to disk for future use. **Parameters** @@ -336,7 +335,6 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService * **proxies** (`Optional`\[`dict`]) – Proxy configuration. Supported optional keys are `urls` (a dictionary mapping protocol or protocol and host to the URL of the proxy, documented at [https://docs.python-requests.org/en/latest/api/#requests.Session.proxies](https://docs.python-requests.org/en/latest/api/#requests.Session.proxies)), `username_ntlm`, `password_ntlm` (username and password to enable NTLM user authentication) * **verify** (`Optional`\[`bool`]) – Verify the server’s TLS certificate. * **overwrite** (`Optional`\[`bool`]) – `True` if the existing account is to be overwritten. - * **channel\_strategy** (`Optional`\[`str`]) – (DEPRECATED) Error mitigation strategy. * **set\_as\_default** (`Optional`\[`bool`]) – If `True`, the account is saved in filename, as the default account. * **private\_endpoint** (`Optional`\[`bool`]) – Connect to private API URL. @@ -347,7 +345,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### saved\_accounts - + List the accounts saved on disk. **Parameters** @@ -372,7 +370,7 @@ python_api_name: qiskit_ibm_runtime.QiskitRuntimeService ### usage - + Return monthly open plan usage information. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeDecoder.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeDecoder.mdx index 8ff0f862699..8945d3f5a49 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeDecoder.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeDecoder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeDecoder # RuntimeDecoder - + JSON Decoder used by runtime service. `object_hook`, if specified, will be called with the result of every JSON object decoded and its return value will be used in place of the given `dict`. This can be used to provide custom deserializations (e.g. to support JSON-RPC class hinting). @@ -33,7 +33,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeDecoder ### object\_hook - + Called to decode object. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeEncoder.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeEncoder.mdx index 12811df1999..fae39afaee2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeEncoder.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeEncoder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeEncoder # RuntimeEncoder - + JSON Encoder used by runtime service. Constructor for JSONEncoder, with sensible defaults. @@ -43,7 +43,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeEncoder ### default - + Implement this method in a subclass such that it returns a serializable object for `o`, or calls the base implementation (to raise a `TypeError`). For example, to support arbitrary iterators, you could implement default like this: diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob.mdx index b88bfd635be..25c0b1376f1 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob # RuntimeJob - + Representation of a runtime primitive execution. A new `RuntimeJob` instance is returned when you call `QiskitRuntimeService.run` to execute a runtime primitive, or [`QiskitRuntimeService.job`](qiskit_ibm_runtime.QiskitRuntimeService#job "qiskit_ibm_runtime.QiskitRuntimeService.job") to retrieve a previously executed job. @@ -27,7 +27,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob print("Job failed!: {}".format(ex)) ``` - If the primitive has any interim results, you can use the `callback` parameter of the `run()` method to stream the interim results along with the final result. Alternatively, you can use the [`stream_results()`](#qiskit_ibm_runtime.RuntimeJob.stream_results "qiskit_ibm_runtime.RuntimeJob.stream_results") method to stream the results at a later time, but before the job finishes. + If the primitive has any interim results, you can use the `callback` parameter of the `run()` method to stream the interim results along with the final result. Alternatively, you can use the `stream_results()` method to stream the results at a later time, but before the job finishes. RuntimeJob constructor. @@ -165,7 +165,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### backend - + Return the backend where this job was executed. Retrieve data again if backend is None. **Raises** @@ -179,7 +179,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### cancel - + Cancel the job. **Raises** @@ -194,7 +194,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### cancel\_result\_streaming - + Cancel result streaming. **Return type** @@ -224,7 +224,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### error\_message - + Returns the reason if the job failed. **Return type** @@ -238,7 +238,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### errored - + Return whether the job has failed. **Return type** @@ -248,7 +248,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -256,28 +256,6 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob `bool` - ### interim\_results - - - (DEPRECATED) Return the interim results of the job. - - **Parameters** - - **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode interim results. - - **Return type** - - `Any` - - **Returns** - - Runtime job interim results. - - **Raises** - - **RuntimeJobFailureError** – If the job failed. - - ### job\_id @@ -290,7 +268,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### logs - + Return job logs. @@ -312,7 +290,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### metrics - + Return job metrics. **Returns** @@ -334,7 +312,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### properties - + Return the backend properties for this job. **Parameters** @@ -352,7 +330,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### queue\_info - + Return queue information for this job. The queue information may include queue position, estimated start and end time, and dynamic priorities for the hub, group, and project. See `QueueInfo` for more information. @@ -372,7 +350,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### queue\_position - + Return the position of the job in the server queue. @@ -394,7 +372,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### result - + Return the results of the job. **Parameters** @@ -429,7 +407,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### status - + Return the status of the job. **Return type** @@ -441,34 +419,9 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob Status of this job. - ### stream\_results - - - (DEPRECATED) Start streaming job results. - - **Parameters** - - * **callback** (`Callable`) – - - Callback function to be invoked for any interim results and final result. The callback function will receive 2 positional parameters: - - > 1. Job ID - > 2. Job result. - - * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. - - **Raises** - - **RuntimeInvalidStateError** – If a callback function is already streaming results or if the job already finished. - - **Return type** - - `None` - - ### submit - + Unsupported method. .. note: ```python @@ -488,7 +441,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### update\_tags - + Update the tags associated with this job. **Parameters** @@ -510,7 +463,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### usage - + Return job usage in seconds. **Return type** @@ -520,7 +473,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJob ### wait\_for\_final\_state - + Poll for the job status from the API until the status is in a final state. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJobV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJobV2.mdx index c4347d7223b..b8243c3892f 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJobV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJobV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 # RuntimeJobV2 - + Representation of a runtime V2 primitive exeuction. RuntimeJob constructor. @@ -143,7 +143,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### backend - + Return the backend where this job was executed. Retrieve data again if backend is None. **Raises** @@ -157,7 +157,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### cancel - + Cancel the job. **Raises** @@ -172,7 +172,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### cancel\_result\_streaming - + Cancel result streaming. **Return type** @@ -182,7 +182,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### cancelled - + Return whether the job has been cancelled. **Return type** @@ -192,7 +192,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### done - + Return whether the job has successfully run. **Return type** @@ -202,7 +202,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### error\_message - + Returns the reason if the job failed. **Return type** @@ -216,7 +216,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### errored - + Return whether the job has failed. **Return type** @@ -226,7 +226,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### in\_final\_state - + Return whether the job is in a final job state such as `DONE` or `ERROR`. **Return type** @@ -234,28 +234,6 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 `bool` - ### interim\_results - - - (DEPRECATED) Return the interim results of the job. - - **Parameters** - - **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode interim results. - - **Return type** - - `Any` - - **Returns** - - Runtime job interim results. - - **Raises** - - **RuntimeJobFailureError** – If the job failed. - - ### job\_id @@ -268,7 +246,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### logs - + Return job logs. @@ -290,7 +268,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### metrics - + Return job metrics. **Returns** @@ -312,7 +290,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### properties - + Return the backend properties for this job. **Parameters** @@ -330,7 +308,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### result - + Return the results of the job. **Parameters** @@ -355,7 +333,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### running - + Return whether the job is actively running. **Return type** @@ -365,7 +343,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### status - + Return the status of the job. **Return type** @@ -377,34 +355,9 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 Status of this job. - ### stream\_results - - - (DEPRECATED) Start streaming job results. - - **Parameters** - - * **callback** (`Callable`) – - - Callback function to be invoked for any interim results and final result. The callback function will receive 2 positional parameters: - - > 1. Job ID - > 2. Job result. - - * **decoder** (`Optional`\[`Type`\[`ResultDecoder`]]) – A `ResultDecoder` subclass used to decode job results. - - **Raises** - - **RuntimeInvalidStateError** – If a callback function is already streaming results or if the job already finished. - - **Return type** - - `None` - - ### update\_tags - + Update the tags associated with this job. **Parameters** @@ -426,7 +379,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### usage - + Return job usage in seconds. **Return type** @@ -436,7 +389,7 @@ python_api_name: qiskit_ibm_runtime.RuntimeJobV2 ### wait\_for\_final\_state - + Poll for the job status from the API until the status is in a final state. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler.mdx index 9c08360a745..f16ca006718 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.Sampler # Sampler - + alias of [`SamplerV2`](qiskit_ibm_runtime.SamplerV2 "qiskit_ibm_runtime.sampler.SamplerV2") diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.SamplerV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.SamplerV2.mdx index e906e9e6537..9788f0f780b 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.SamplerV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.SamplerV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.SamplerV2 # SamplerV2 - + Class for interacting with Qiskit Runtime Sampler primitive service. This class supports version 2 of the Sampler interface, which uses different input and output formats than version 1. @@ -33,10 +33,6 @@ python_api_name: qiskit_ibm_runtime.SamplerV2 * **options** (`Union`\[`Dict`, [`SamplerOptions`](qiskit_ibm_runtime.options.SamplerOptions "qiskit_ibm_runtime.options.sampler_options.SamplerOptions"), `None`]) – Sampler options, see `SamplerOptions` for detailed description. - **Raises** - - **NotImplementedError** – If “q-ctrl” channel strategy is used. - ## Attributes ### mode @@ -69,9 +65,19 @@ python_api_name: qiskit_ibm_runtime.SamplerV2 ## Methods + ### backend + + + Return the backend the primitive query will be run on. + + **Return type** + + BackendV1 | BackendV2 + + ### run - + Submit a request to the sampler primitive. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session.mdx index dc5416a8ecb..588624e551b 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.Session # Session - + Class for creating a Qiskit Runtime session. A Qiskit Runtime `session` allows you to group a collection of iterative calls to the quantum computer. A session is started when the first job within the session is started. Subsequent jobs within the session are prioritized by the scheduler. @@ -90,7 +90,7 @@ python_api_name: qiskit_ibm_runtime.Session ### backend - + Return backend for this session. **Return type** @@ -104,7 +104,7 @@ python_api_name: qiskit_ibm_runtime.Session ### cancel - + Cancel all pending jobs in a session. **Return type** @@ -114,7 +114,7 @@ python_api_name: qiskit_ibm_runtime.Session ### close - + Close the session so new jobs will no longer be accepted, but existing queued or running jobs will run to completion. The session will be terminated once there are no more pending jobs. **Return type** @@ -124,7 +124,7 @@ python_api_name: qiskit_ibm_runtime.Session ### details - + Return session details. **Return type** @@ -153,7 +153,7 @@ python_api_name: qiskit_ibm_runtime.Session ### from\_id - + Construct a Session object with a given session\_id **Parameters** @@ -179,7 +179,7 @@ python_api_name: qiskit_ibm_runtime.Session ### status - + Return current session status. **Return type** @@ -199,7 +199,7 @@ python_api_name: qiskit_ibm_runtime.Session ### usage - + Return session usage in seconds. Session usage is the time from when the first job starts until the session goes inactive, is closed, or when its last job completes, whichever happens last. diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.Neat.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.Neat.mdx index 42088766f7a..6f6633ffc02 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.Neat.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.Neat.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.Neat # Neat - + A class to help understand the expected performance of estimator jobs. The “Noisy Estimator Analyzer Tool” (or “NEAT”) is a convenience tool that users of the `Estimator` primitive can employ to analyze and predict the performance of their queries. Its simulate method uses `qiskit-aer` to simulate the estimation task classically efficiently, either in ideal conditions or in the presence of noise. The simulations’ results can be compared with other simulation results or with primitive results results to draw custom figures of merit. @@ -34,7 +34,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.Neat ### backend - + The backend used by this analyzer tool. **Return type** @@ -44,7 +44,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.Neat ### ideal\_sim - + Perform an ideal, noiseless simulation of the estimator task specified by `pubs`. This function uses `qiskit-aer`’s `Estimator` class to simulate the estimation task classically. @@ -71,7 +71,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.Neat ### noisy\_sim - + Perform a noisy simulation of the estimator task specified by `pubs`. This function uses `qiskit-aer`’s `Estimator` class to simulate the estimation task classically. @@ -98,7 +98,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.Neat ### to\_clifford - + Return the cliffordized version of the given `pubs`. This convenience method runs the `ConvertISAToClifford` transpiler pass on the PUBs’ circuits. diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx index 544ead60137..385e146dc08 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatPubResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.NeatPubResult # NeatPubResult - + A class to store the PUB results of `Neat`. It allows performing mathematical operations (`+`, `-`, `*`, `/`, `abs`, and `**`) with other objects of type `NeatPubResultLike` and with scalars. @@ -33,7 +33,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.NeatPubResult ### \_\_mul\_\_ - + **Return type** [`NeatPubResult`](#qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.neat_results.NeatPubResult") diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatResult.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatResult.mdx index c5f6bd9daec..c5cda4833b3 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatResult.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.debug_tools.NeatResult.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.NeatResult # NeatResult - + A container for multiple [`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.NeatPubResult") objects. **Parameters** @@ -19,7 +19,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.NeatResult ### \_\_getitem\_\_ - + **Return type** [`NeatPubResult`](qiskit_ibm_runtime.debug_tools.NeatPubResult "qiskit_ibm_runtime.debug_tools.neat_results.NeatPubResult") @@ -27,7 +27,7 @@ python_api_name: qiskit_ibm_runtime.debug_tools.NeatResult ### \_\_len\_\_ - + **Return type** `int` diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx new file mode 100644 index 00000000000..6eff76aafd6 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.DoubleSliceSpan.mdx @@ -0,0 +1,128 @@ +--- +title: DoubleSliceSpan +description: API reference for qiskit_ibm_runtime.execution_span.DoubleSliceSpan +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit_ibm_runtime.execution_span.DoubleSliceSpan +--- + +# DoubleSliceSpan + + + An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. + + This type of execution span references pub result data by assuming that it is a sliceable portion of the data where the shots are the outermost slice and the rest of the data is flattened. Therefore, for each pub dependent on this span, the constructor accepts two `slice` objects, along with the corresponding shape of the data to be sliced; in contrast to [`SliceSpan`](qiskit_ibm_runtime.execution_span.SliceSpan "qiskit_ibm_runtime.execution_span.SliceSpan"), this class does not assume that *all* shots for a particular set of parameter values are contiguous in the array of data. + + **Parameters** + + * **start** (`datetime`) – The start time of the span, in UTC. + * **stop** (`datetime`) – The stop time of the span, in UTC. + * **data\_slices** (`dict`\[`int`, `tuple`\[`Tuple`\[`int`, `...`], `slice`, `slice`]]) – A map from pub indices to `(shape_tuple, slice, slice)`. + + ## Attributes + + ### duration + + + The duration of this span, in seconds. + + **Return type** + + `float` + + + ### pub\_idxs + + + **Return type** + + `list`\[`int`] + + + ### size + + + **Return type** + + `int` + + + ### start + + + The start time of the span, in UTC. + + **Return type** + + `datetime` + + + ### stop + + + The stop time of the span, in UTC. + + **Return type** + + `datetime` + + + ## Methods + + ### contains\_pub + + + Return whether the pub with the given index has data with dependence on this span. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + bool + + **Returns** + + Whether there is dependence on this span. + + + ### filter\_by\_pub + + + Return a new span whose slices are filtered to the provided pub indices. + + For example, if this span contains slice information for pubs with indices 1, 3, 4 and `[1, 4]` is provided, then the span returned by this method will contain slice information for only those two indices, but be identical otherwise. + + **Parameters** + + **pub\_idx** (*int | Iterable\[int]*) – One or more pub indices from the original primitive call. + + **Return type** + + [DoubleSliceSpan](#qiskit_ibm_runtime.execution_span.DoubleSliceSpan "qiskit_ibm_runtime.execution_span.DoubleSliceSpan") + + **Returns** + + A new filtered span. + + + ### mask + + + Return an array-valued mask specifying which parts of a pub result depend on this span. + + **Parameters** + + **pub\_idx** (`int`) – The index of the pub to return a mask for. + + **Return type** + + [`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v2.1)")\[`Any`, [`dtype`](https://numpy.org/doc/stable/reference/generated/numpy.dtype.html#numpy.dtype "(in NumPy v2.1)")\[[`bool`](https://numpy.org/doc/stable/reference/arrays.scalars.html#numpy.bool "(in NumPy v2.1)")]] + + **Returns** + + An array with the same shape as the pub data. + + + diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx index d225a962fb3..d9d66f13e59 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpan.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpan # ExecutionSpan - + Abstract parent for classes that store an execution time span for a subset of job data. A pub is said to have dependence on an execution span if the corresponding execution includes data that forms any part of the pub’s results. @@ -84,7 +84,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpan ### contains\_pub - + Return whether the pub with the given index has data with dependence on this span. **Parameters** @@ -102,7 +102,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpan ### filter\_by\_pub - + Return a new span whose slices are filtered to the provided pub indices. For example, if this span contains slice information for pubs with indices 1, 3, 4 and `[1, 4]` is provided, then the span returned by this method will contain slice information for only those two indices, but be identical otherwise. @@ -122,7 +122,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpan ### mask - + Return an array-valued mask specifying which parts of a pub result depend on this span. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx index f8c3cc4ad89..b83deca36a0 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.ExecutionSpans.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans # ExecutionSpans - + A collection of timings for pub results. This class is a list-like containing [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan")s, where each execution span represents a time window of data collection, and contains a reference to exactly which of the data were collected during the window. @@ -61,7 +61,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans ### \_\_getitem\_\_ - + **Return type** [ExecutionSpan](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") | ‘ExecutionSpans @@ -69,15 +69,39 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans ### \_\_len\_\_ - + **Return type** `int` + ### draw + + + Draw these execution spans. + + + To draw multiple sets of execution spans at once, for example coming from multiple jobs, consider calling [`draw_execution_spans()`](qiskit_ibm_runtime.visualization.draw_execution_spans "qiskit_ibm_runtime.visualization.draw_execution_spans") directly. + + + **Parameters** + + * **name** (`Optional`\[`str`]) – The name of this set of spans. + * **normalize\_y** (`bool`) – Whether to display the y-axis units as a percentage of work complete, rather than cumulative shots completed. + * **line\_width** (`int`) – The thickness of line segments. + + **Return type** + + `Figure` + + **Returns** + + A plotly figure. + + ### filter\_by\_pub - + Return a new set of spans where each one has been filtered to the specified pubs. See also :meth:\~.ExecutionSpan.filter\_by\_pub\`. @@ -93,7 +117,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.ExecutionSpans ### sort - + Return the same execution spans, sorted. Sorting is done by the [`start`](qiskit_ibm_runtime.execution_span.ExecutionSpan#start "qiskit_ibm_runtime.execution_span.ExecutionSpan.start") timestamp of each execution span. diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.SliceSpan.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.SliceSpan.mdx index 61d5b35a550..6b2996dcbfa 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.SliceSpan.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.execution_span.SliceSpan.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.SliceSpan # SliceSpan - + An [`ExecutionSpan`](qiskit_ibm_runtime.execution_span.ExecutionSpan "qiskit_ibm_runtime.execution_span.ExecutionSpan") for data stored in a sliceable format. This type of execution span references pub result data by assuming that it is a sliceable portion of the (row major) flattened data. Therefore, for each pub dependent on this span, the constructor accepts a single `slice` object, along with the corresponding shape of the data to be sliced. @@ -71,7 +71,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.SliceSpan ### contains\_pub - + Return whether the pub with the given index has data with dependence on this span. **Parameters** @@ -89,7 +89,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.SliceSpan ### filter\_by\_pub - + Return a new span whose slices are filtered to the provided pub indices. For example, if this span contains slice information for pubs with indices 1, 3, 4 and `[1, 4]` is provided, then the span returned by this method will contain slice information for only those two indices, but be identical otherwise. @@ -109,7 +109,7 @@ python_api_name: qiskit_ibm_runtime.execution_span.SliceSpan ### mask - + Return an array-valued mask specifying which parts of a pub result depend on this span. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx index c32045eb8bb..4875a93dfa6 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlgiers.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers # FakeAlgiers - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlgiers ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx index 8022c3e591d..565a633110e 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAlmadenV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 # FakeAlmadenV2 - + A fake Almaden V2 backend. ```python @@ -219,7 +219,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -235,7 +235,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### configuration - + Return the backend configuration. **Return type** @@ -263,7 +263,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -285,7 +285,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -304,7 +304,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -320,7 +320,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -336,7 +336,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### properties - + Return the backend properties **Parameters** @@ -379,7 +379,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -404,7 +404,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -449,7 +449,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAlmadenV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx index 07110a2a402..f7c6c099db3 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeArmonkV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 # FakeArmonkV2 - + A fake 1 qubit backend. ```python @@ -213,7 +213,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -229,7 +229,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -247,7 +247,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### configuration - + Return the backend configuration. **Return type** @@ -257,7 +257,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -279,7 +279,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -298,7 +298,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -314,7 +314,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -330,7 +330,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### properties - + Return the backend properties **Parameters** @@ -373,7 +373,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -398,7 +398,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -443,7 +443,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeArmonkV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx index c75f05f41ac..8d1abdd63e2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAthensV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 # FakeAthensV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAthensV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx index 3ed88fdd8e1..05abd1441f9 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeAuckland.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland # FakeAuckland - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeAuckland ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx index ca168c10b43..0b4358a4ae9 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBelemV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 # FakeBelemV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBelemV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx index 5d81f536d7c..283dd0341ab 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 # FakeBoeblingenV2 - + A fake Boeblingen V2 backend. ```python @@ -219,7 +219,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -235,7 +235,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### configuration - + Return the backend configuration. **Return type** @@ -263,7 +263,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -285,7 +285,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -304,7 +304,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -320,7 +320,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -336,7 +336,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### properties - + Return the backend properties **Parameters** @@ -379,7 +379,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -404,7 +404,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -449,7 +449,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBoeblingenV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx index 5e43b960539..e004ebd2b21 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBogotaV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 # FakeBogotaV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBogotaV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx index 021c2847210..5590da57066 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrisbane.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane # FakeBrisbane - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrisbane ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx index 336893a30e4..c673c47f9bd 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBrooklynV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 # FakeBrooklynV2 - + A fake Brooklyn V2 backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBrooklynV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx index 6aa31b665f8..dd0a2cfdc3d 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 # FakeBurlingtonV2 - + A fake 5 qubit backend. ```python @@ -215,7 +215,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -231,7 +231,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -249,7 +249,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### configuration - + Return the backend configuration. **Return type** @@ -259,7 +259,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -281,7 +281,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -300,7 +300,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -316,7 +316,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -332,7 +332,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### properties - + Return the backend properties **Parameters** @@ -375,7 +375,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -400,7 +400,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -445,7 +445,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeBurlingtonV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx index b08db244ec1..2193401e88c 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCairoV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 # FakeCairoV2 - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCairoV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx index 5876f4f0c60..e96eebe81e8 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCambridgeV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 # FakeCambridgeV2 - + A fake Cambridge backend. ```python @@ -221,7 +221,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -237,7 +237,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -255,7 +255,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### configuration - + Return the backend configuration. **Return type** @@ -265,7 +265,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -287,7 +287,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -306,7 +306,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -322,7 +322,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -338,7 +338,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### properties - + Return the backend properties **Parameters** @@ -381,7 +381,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -406,7 +406,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -451,7 +451,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCambridgeV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx index 3200dccd376..03d7d3e5a88 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCasablancaV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 # FakeCasablancaV2 - + A fake 7 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCasablancaV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx index 8fdc03729c5..f59caae607b 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeCusco.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco # FakeCusco - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeCusco ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx index 42ceff241dc..f5100111307 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeEssexV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 # FakeEssexV2 - + A fake 5 qubit backend. ```python @@ -217,7 +217,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -233,7 +233,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -251,7 +251,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### configuration - + Return the backend configuration. **Return type** @@ -261,7 +261,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -283,7 +283,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -302,7 +302,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -318,7 +318,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -334,7 +334,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### properties - + Return the backend properties **Parameters** @@ -377,7 +377,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -402,7 +402,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -447,7 +447,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeEssexV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx index 2cf022e9536..7870c2643a6 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeFractionalBackend.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend # FakeFractionalBackend - + A fake 5 qubit backend with dynamic and fractional feature modeled based on FakeLima. This backend include following features. @@ -216,7 +216,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -232,7 +232,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -250,7 +250,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### configuration - + Return the backend configuration. **Return type** @@ -260,7 +260,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -282,7 +282,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -301,7 +301,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -317,7 +317,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -333,7 +333,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### properties - + Return the backend properties **Parameters** @@ -376,7 +376,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -401,7 +401,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -446,7 +446,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeFractionalBackend ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx index 01fdfcce0fe..162a102c7d2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGeneva.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva # FakeGeneva - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGeneva ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx index 15c0e866261..be26b0e8212 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 # FakeGuadalupeV2 - + A fake 16 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeGuadalupeV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx index ab96df41c4d..e810fa03cbd 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeHanoiV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 # FakeHanoiV2 - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeHanoiV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx index cb03b8dc162..73bcf6234f7 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJakartaV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 # FakeJakartaV2 - + A fake 7 qubit V2 backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJakartaV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx index 70d39f63125..d14fac42f11 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 # FakeJohannesburgV2 - + A fake Johannesburg V2 backend. ```python @@ -219,7 +219,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -235,7 +235,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### configuration - + Return the backend configuration. **Return type** @@ -263,7 +263,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -285,7 +285,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -304,7 +304,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -320,7 +320,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -336,7 +336,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### properties - + Return the backend properties **Parameters** @@ -379,7 +379,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -404,7 +404,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -449,7 +449,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeJohannesburgV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx index 3649e87c980..a3f8bf37a72 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKawasaki.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki # FakeKawasaki - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKawasaki ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx index bb01b7c20e9..3aa5146d2b2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKolkataV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 # FakeKolkataV2 - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKolkataV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx index 8dc985d2eab..92c6298c371 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyiv.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv # FakeKyiv - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyiv ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx index b8f745b7c6c..fda4f96e80e 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeKyoto.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto # FakeKyoto - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeKyoto ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx index 785308c0508..72b82918066 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLagosV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 # FakeLagosV2 - + A fake 7 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLagosV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx index 2d0b2179389..b093fff8e90 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLimaV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 # FakeLimaV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLimaV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx index c8265710a69..27bebc2fd4a 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeLondonV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 # FakeLondonV2 - + A fake 5 qubit backend. ```python @@ -217,7 +217,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -233,7 +233,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -251,7 +251,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### configuration - + Return the backend configuration. **Return type** @@ -261,7 +261,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -283,7 +283,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -302,7 +302,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -318,7 +318,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -334,7 +334,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### properties - + Return the backend properties **Parameters** @@ -377,7 +377,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -402,7 +402,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -447,7 +447,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeLondonV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx index 566e2f5a7d9..ca3043f7ac1 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManhattanV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 # FakeManhattanV2 - + A fake Manhattan backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManhattanV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx index d42d71fb2b6..583a2f624e4 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeManilaV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 # FakeManilaV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeManilaV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx index f987ea5b87a..acec5863cd4 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMelbourneV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 # FakeMelbourneV2 - + A fake 14 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMelbourneV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx index 124e32c77b5..545931feb28 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMontrealV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 # FakeMontrealV2 - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMontrealV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx index f141e5ee473..0c0c0a8f38b 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeMumbaiV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 # FakeMumbaiV2 - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeMumbaiV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx index ca7c9f1ead7..bf685aac9ac 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeNairobiV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 # FakeNairobiV2 - + A fake 7 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeNairobiV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx index 4d2340a7295..347a72ce7ff 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOsaka.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka # FakeOsaka - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOsaka ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx index 5a00c34d949..4ed893eed9c 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOslo.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo # FakeOslo - + A fake 7 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOslo ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx index 660dd42ebef..722178bb390 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeOurenseV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 # FakeOurenseV2 - + A fake 5 qubit backend. ```python @@ -215,7 +215,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -231,7 +231,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -249,7 +249,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### configuration - + Return the backend configuration. **Return type** @@ -259,7 +259,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -281,7 +281,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -300,7 +300,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -316,7 +316,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -332,7 +332,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### properties - + Return the backend properties **Parameters** @@ -375,7 +375,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -400,7 +400,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -445,7 +445,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeOurenseV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx index 8071be20e3d..45cc41bd657 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeParisV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 # FakeParisV2 - + A fake Paris backend. ```python @@ -221,7 +221,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -237,7 +237,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -255,7 +255,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### configuration - + Return the backend configuration. **Return type** @@ -265,7 +265,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -287,7 +287,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -306,7 +306,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -322,7 +322,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -338,7 +338,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### properties - + Return the backend properties **Parameters** @@ -381,7 +381,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -406,7 +406,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -451,7 +451,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeParisV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx index 0bee3fd7398..3feddb0353a 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePeekskill.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill # FakePeekskill - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePeekskill ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePerth.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePerth.mdx index 2c3b233bffd..7b918eaa813 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePerth.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePerth.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth # FakePerth - + A fake 7 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePerth ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx index 01a4f6c35ab..2f2923d729e 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 # FakePoughkeepsieV2 - + A fake Poughkeepsie backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePoughkeepsieV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePrague.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePrague.mdx index bed93f13811..ee22661a2f8 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePrague.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakePrague.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague # FakePrague - + A fake 33 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakePrague ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx index 771050045a2..7f6ff1abf48 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2 # FakeProviderForBackendV2 - + Fake provider containing fake V2 backends. Only filtering backends by name is implemented. This class contains all fake V2 backends available in the [`qiskit_ibm_runtime.fake_provider`](fake_provider#module-qiskit_ibm_runtime.fake_provider "qiskit_ibm_runtime.fake_provider"). @@ -17,7 +17,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2 ### backend - + Filter backends in provider by name. **Return type** @@ -27,7 +27,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeProviderForBackendV2 ### backends - + Return all backends accessible via this account. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx index 0dd6397beb6..385c1cbc018 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuebec.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec # FakeQuebec - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuebec ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx index 8226331957a..364755185b2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeQuitoV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 # FakeQuitoV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeQuitoV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx index be2b9df06a3..ca31ad52116 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRochesterV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 # FakeRochesterV2 - + A fake Rochester backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRochesterV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx index 4ce5ef12271..2a3ec1b7b7c 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeRomeV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 # FakeRomeV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeRomeV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx index e084bbea270..04ef452058c 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSantiagoV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 # FakeSantiagoV2 - + A fake Santiago backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSantiagoV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx index 7f6bb665588..bb2cc408193 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSherbrooke.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke # FakeSherbrooke - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSherbrooke ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx index f62977bc9c1..7978f4d5221 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSingaporeV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 # FakeSingaporeV2 - + A fake Singapore backend. ```python @@ -219,7 +219,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -235,7 +235,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### configuration - + Return the backend configuration. **Return type** @@ -263,7 +263,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -285,7 +285,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -304,7 +304,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -320,7 +320,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -336,7 +336,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### properties - + Return the backend properties **Parameters** @@ -379,7 +379,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -404,7 +404,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -449,7 +449,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSingaporeV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx index 8c1f6dd4ebb..45fc6283a29 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeSydneyV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 # FakeSydneyV2 - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeSydneyV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx index 20b0538a6f9..31f712308bc 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorino.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino # FakeTorino - + A fake 133 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorino ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx index 68a5a650a3e..e5a63f54fcb 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeTorontoV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 # FakeTorontoV2 - + A fake 27 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeTorontoV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx index 8a388446ee1..86f116fb817 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeValenciaV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 # FakeValenciaV2 - + A fake 5 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeValenciaV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx index 030237b25f1..bec84a3dc7b 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeVigoV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 # FakeVigoV2 - + A fake 5 qubit backend. ```python @@ -215,7 +215,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -231,7 +231,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -249,7 +249,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### configuration - + Return the backend configuration. **Return type** @@ -259,7 +259,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -281,7 +281,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -300,7 +300,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -316,7 +316,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -332,7 +332,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### properties - + Return the backend properties **Parameters** @@ -375,7 +375,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -400,7 +400,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -445,7 +445,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeVigoV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx index 8a6959ca804..323cae861ac 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeWashingtonV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 # FakeWashingtonV2 - + A fake 127 qubit backend. FakeBackendV2 initializer. @@ -209,7 +209,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -225,7 +225,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -243,7 +243,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### configuration - + Return the backend configuration. **Return type** @@ -253,7 +253,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -275,7 +275,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -294,7 +294,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -310,7 +310,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -326,7 +326,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### properties - + Return the backend properties **Parameters** @@ -369,7 +369,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -394,7 +394,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -439,7 +439,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeWashingtonV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx index ca7d472bd98..1190c7ec145 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.fake_provider.FakeYorktownV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 # FakeYorktownV2 - + A fake 5 qubit backend. ```python @@ -217,7 +217,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### acquire\_channel - + Return the acquisition channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -233,7 +233,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### check\_faulty - + Check if the input circuit uses faulty qubits or edges. **Parameters** @@ -251,7 +251,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### configuration - + Return the backend configuration. **Return type** @@ -261,7 +261,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### control\_channel - + Return the secondary drive channel for the given qubit This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. @@ -283,7 +283,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### defaults - + Return the pulse defaults for the backend **Parameters** @@ -302,7 +302,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### drive\_channel - + Return the drive channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -318,7 +318,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### measure\_channel - + Return the measure stimulus channel for the given qubit. This is required to be implemented if the backend supports Pulse scheduling. @@ -334,7 +334,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### properties - + Return the backend properties **Parameters** @@ -377,7 +377,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### refresh - + Update the data files from its real counterpart This method pulls the latest backend data files from their real counterpart and overwrites the corresponding files in the local installation: \* ../fake\_provider/backends/\{backend\_name}/conf\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/defs\_\{backend\_name}.json \* ../fake\_provider/backends/\{backend\_name}/props\_\{backend\_name}.json @@ -402,7 +402,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### run - + Run on the fake backend using a simulator. This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using BasicSimulator or Aer simulator and returns a [`Job`](/api/qiskit/qiskit.providers.Job "(in Qiskit v1.2)") object. @@ -447,7 +447,7 @@ python_api_name: qiskit_ibm_runtime.fake_provider.FakeYorktownV2 ### status - + Return the backend status. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx index 108e9ee995f..dfcbb41336c 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.noise_learner.NoiseLearner.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.noise_learner.NoiseLearner # NoiseLearner - + Class for executing noise learning experiments. @@ -73,7 +73,7 @@ python_api_name: qiskit_ibm_runtime.noise_learner.NoiseLearner **References** - 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages 1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) ## Attributes @@ -89,9 +89,19 @@ python_api_name: qiskit_ibm_runtime.noise_learner.NoiseLearner ## Methods + ### backend + + + Return the backend the primitive query will be run on. + + **Return type** + + [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)") + + ### run - + Submit a request to the noise learner program. This function breaks the given list of circuits into a list of unique layers, following the strategy set by the `twirling_strategy` field specified in the `options` (see `NoiseLearnerOptions` for more details) and sorting them based on the number of times they occur in the various circuits. Then, it runs the noise learning experiment for as many layers as specified by the `max_layers_to_learn` field in the `options`, prioritizing layers that occurr more frequently. diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx index 7d027ba33ac..0f0e7b18fa3 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.DynamicalDecouplingOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.DynamicalDecouplingOptions # DynamicalDecouplingOptions - + Options for dynamical decoupling (DD). ## Attributes @@ -59,6 +59,16 @@ python_api_name: qiskit_ibm_runtime.options.DynamicalDecouplingOptions `tau/2 - (+X) - tau - (+Y) - tau (-X) - tau - (-Y) - tau/2` + ### skip\_reset\_qubits + + + Whether to insert DD on idle periods that immediately follow initialized/reset qubits. + + Since qubits in the ground state are less susceptible to decoherence, it can be beneficial to let them be while they are known to be in this state. + + Default: False. + + ## Methods diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EnvironmentOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EnvironmentOptions.mdx index 91d916b9e7c..0b4ee76cfcb 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EnvironmentOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EnvironmentOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.EnvironmentOptions # EnvironmentOptions - + Options related to the execution environment. ## Attributes diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EstimatorOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EstimatorOptions.mdx index 8d56e9ab5bd..7e31314af2a 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EstimatorOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EstimatorOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.EstimatorOptions # EstimatorOptions - + Options for V2 Estimator. ## Attributes @@ -63,17 +63,6 @@ python_api_name: qiskit_ibm_runtime.options.EstimatorOptions - ### optimization\_level - - - (DEPRECATED) How much optimization to perform on the circuits. Higher levels generate more optimized circuits, at the expense of longer processing times. - - * 0: no optimization - * 1: light optimization - - Default: 0. - - ### resilience @@ -120,7 +109,7 @@ python_api_name: qiskit_ibm_runtime.options.EstimatorOptions ### update - + Update the options. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx index 752c6842d5b..251aca6cb1d 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ExecutionOptionsV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.ExecutionOptionsV2 # ExecutionOptionsV2 - + Execution options for V2 primitives. ## Attributes diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx index eaeefa355ea..f048770e71a 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.LayerNoiseLearningOptions.mdx @@ -8,13 +8,23 @@ python_api_name: qiskit_ibm_runtime.options.LayerNoiseLearningOptions # LayerNoiseLearningOptions - + Options for learning layer noise. This is only used by V2 Estimator. These options are only used when the resilience level or options specify a technique that requires layer noise learning. + + The total number of unique circuits implemented to learn the noise of a single layer depends solely on [`layer_pair_depths`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.layer_pair_depths "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.layer_pair_depths") and [`num_randomizations`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.num_randomizations "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.num_randomizations"). For example, if `layer_pair_depths` contains six depths and `num_randomizations` is set to `32`, the noise learning stage executes a total of `6 * 9` unique circuits per layer, each one with `32` randomizations (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization") each). + + The number `9` above is the number of unique circuits that need to be implemented to learn the noise for all the two-qubit subsystem in the given layer by performing local measurements. Indeed, learning the noise for a single one of these subsystems requires measuring all the `16` two-qubit Paulis on that subsystem. Taking advantage of commutation relations to measure more than one of these Paulis (for example, `XI`, `IX`, and `XX`) with a single circuit, it is possible to measure all these `16` Paulis by implementing only `9` circuits. Parallelizing these measurement tasks in the optimal way allows then measuring the `16` Paulis for all of the layer’s two-qubit subsystems with only `9` circuits. More details in Ref. \[1]. + + + **References** + + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages 1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + ## Attributes ### layer\_pair\_depths @@ -36,7 +46,7 @@ python_api_name: qiskit_ibm_runtime.options.LayerNoiseLearningOptions ### num\_randomizations - The number of random circuits to use per learning circuit configuration. A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, and nine required measurement bases, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization") each). + The number of random circuits to use per learning circuit configuration. A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (where `9` is the number of circuits that need to be implemented to measure all the required observables, see the note in the docstring for [`LayerNoiseLearningOptions`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions "qiskit_ibm_runtime.options.LayerNoiseLearningOptions") for mode details), at [`shots_per_randomization`](#qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization "qiskit_ibm_runtime.options.LayerNoiseLearningOptions.shots_per_randomization") each. Default: 32. diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx index 956f9d0c9ce..75e01546158 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.MeasureNoiseLearningOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.MeasureNoiseLearningOptions # MeasureNoiseLearningOptions - + Options for measurement noise learning. This is only used by V2 Estimator. diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx index 6c35f2eabea..a3264c12bcd 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.NoiseLearnerOptions.mdx @@ -8,9 +8,19 @@ python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions # NoiseLearnerOptions - + Options for [`NoiseLearner`](qiskit_ibm_runtime.noise_learner.NoiseLearner "qiskit_ibm_runtime.noise_learner.NoiseLearner"). + + The total number of unique circuits implemented to learn the noise of a single layer depends solely on [`layer_pair_depths`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.layer_pair_depths "qiskit_ibm_runtime.options.NoiseLearnerOptions.layer_pair_depths") and [`num_randomizations`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.num_randomizations "qiskit_ibm_runtime.options.NoiseLearnerOptions.num_randomizations"). For example, if `layer_pair_depths` contains six depths and `num_randomizations` is set to `32`, the noise learning stage executes a total of `6 * 9` unique circuits per layer, each one with `32` randomizations (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization "qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization") each). + + The number `9` above is the number of unique circuits that need to be implemented to learn the noise for all the two-qubit subsystem in the given layer by performing local measurements. Indeed, learning the noise for a single one of these subsystems requires measuring all the `16` two-qubit Paulis on that subsystem. Taking advantage of commutation relations to measure more than one of these Paulis (for example, `XI`, `IX`, and `XX`) with a single circuit, it is possible to measure all these `16` Paulis by implementing only `9` circuits. Parallelizing these measurement tasks in the optimal way allows then measuring the `16` Paulis for all of the layer’s two-qubit subsystems with only `9` circuits. More details in Ref. \[1]. + + + **References** + + 1. E. van den Berg, Z. Minev, A. Kandala, K. Temme, *Probabilistic error cancellation with sparse Pauli–Lindblad models on noisy quantum processors*, Nature Physics volume 19, pages 1116–1121 (2023). [arXiv:2201.09866 \[quant-ph\]](https://arxiv.org/abs/2201.09866) + ## Attributes ### environment @@ -30,7 +40,7 @@ python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions The circuit depths (measured in number of pairs) to use in learning experiments. - Pairs are used as the unit because we exploit the order-2 nature of our entangling gates in the noise learning implementation. A value of `3` would correspond to 6 layers of the layer of interest, for example. Default: (0, 1, 2, 4, 16, 32). + Pairs are used as the unit because we exploit the order-2 nature of our entangling gates in the noise learning implementation. For example, a value of `3` corresponds to 6 repetitions of the layer of interest. Default: (0, 1, 2, 4, 16, 32). ### max\_execution\_time @@ -50,7 +60,7 @@ python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions The number of random circuits to use per learning circuit configuration. - A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, and nine required measurement bases, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (at [`shots_per_randomization`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization "qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization") each). Default: 32. + A configuration is a measurement basis and depth setting. For example, if your experiment has six depths, then setting this value to 32 will result in a total of `32 * 9 * 6` circuits that need to be executed (where `9` is the number of circuits that need to be implemented to measure all the required observables, see the note in the docstring for [`NoiseLearnerOptions`](#qiskit_ibm_runtime.options.NoiseLearnerOptions "qiskit_ibm_runtime.options.NoiseLearnerOptions") for mode details), at [`shots_per_randomization`](#qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization "qiskit_ibm_runtime.options.NoiseLearnerOptions.shots_per_randomization") each. ### shots\_per\_randomization @@ -95,7 +105,7 @@ python_api_name: qiskit_ibm_runtime.options.NoiseLearnerOptions ### update - + Update the options. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.PecOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.PecOptions.mdx index 638891240ed..ef4274c1ba9 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.PecOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.PecOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.PecOptions # PecOptions - + Probabalistic error cancellation mitigation options. This is only used by V2 Estimator. ## Attributes diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx index f8f7c85a424..448b69d7a79 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ResilienceOptionsV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.ResilienceOptionsV2 # ResilienceOptionsV2 - + Resilience options for V2 Estimator. ## Attributes diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx index 38f13d7f87b..2fcafc58d9a 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.SamplerExecutionOptionsV2 # SamplerExecutionOptionsV2 - + Extension of [`ExecutionOptionsV2`](qiskit_ibm_runtime.options.ExecutionOptionsV2 "qiskit_ibm_runtime.options.ExecutionOptionsV2") for the sampler primitive. ## Attributes diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerOptions.mdx index 7b156e29866..d051ecde30e 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.SamplerOptions # SamplerOptions - + Options for V2 Sampler. ## Attributes @@ -61,7 +61,7 @@ python_api_name: qiskit_ibm_runtime.options.SamplerOptions ### update - + Update the options. **Return type** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SimulatorOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SimulatorOptions.mdx index e6d6a917368..9932a29be80 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SimulatorOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SimulatorOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.SimulatorOptions # SimulatorOptions - + Simulator options. For best practice in simulating a backend make sure to pass the basis gates and coupling map of that backend. @@ -51,7 +51,7 @@ python_api_name: qiskit_ibm_runtime.options.SimulatorOptions ### set\_backend - + Set backend for simulation. This method changes noise\_model, coupling\_map, basis\_gates according to given backend. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.TwirlingOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.TwirlingOptions.mdx index 42be9a5ebeb..3e0a31e3ff2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.TwirlingOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.TwirlingOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.TwirlingOptions # TwirlingOptions - + Twirling options. ## Attributes diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ZneOptions.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ZneOptions.mdx index 70b47e566d2..ebc1aa366b7 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ZneOptions.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.ZneOptions.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.options.ZneOptions # ZneOptions - + Zero noise extrapolation mitigation options. This is only used by the V2 Estimator. @@ -22,7 +22,7 @@ python_api_name: qiskit_ibm_runtime.options.ZneOptions 2. `pub_result.data.evs_noise_factors`, `pub_result.data.stds_noise_factors`, and `ensemble_stds_noise_factors` all have shape `(*shape, num_noise_factors)` where `num_noise_factors` is the length of `options.resilience.zne.noise_factors`. These values provide evaluations of the best-fit model at each of the noise amplifications. In the case of no twirling, both `*stds*` arrays will be equal, otherwise, `stds_noise_factors` is derived from the spread over twirling samples, whereas `ensemble_stds_noise_factors` assumes only shot noise and no drift. - Technical note: for single observables with multiple basis terms it might turn out that multiple extrapolation methods are used in *the same* expectation value, for example, `XX` gets linearly extrapolated but `XY` gets exponentially extrapolated in the observable `{"XX": 0.5, "XY": 0.5}`. Let’s call this a *hetergeneous fit*. The data from (2) is evaluated from heterogeneous fits by selecting the best fit for every individual distinct term, whereas data from (1) is evaluated from forced homogenous fits, one for each provided extrapolator. If your work requires a nuanced distinction in this regard, we presently recommend that you use single-term observables in addition to your multi-term observables. + Technical note: for single observables with multiple basis terms it might turn out that multiple extrapolation methods are used in *the same* expectation value, for example, `XX` gets linearly extrapolated but `XY` gets exponentially extrapolated in the observable `{"XX": 0.5, "XY": 0.5}`. Let’s call this a *heterogeneous fit*. The data from (2) is evaluated from heterogeneous fits by selecting the best fit for every individual distinct term, whereas data from (1) is evaluated from forced homogenous fits, one for each provided extrapolator. If your work requires a nuanced distinction in this regard, we presently recommend that you use single-term observables in addition to your multi-term observables. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx index c88e83e4424..d118750d937 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford # ConvertISAToClifford - + Convert the gates of an ISA circuit to Clifford gates. ISA circuits only contain Clifford gates from a restricted set or [`qiskit.circuit.library.RZGate`](/api/qiskit/qiskit.circuit.library.RZGate "(in Qiskit v1.2)")s by arbitrary angles. To convert them to Clifford circuits, this pass rounds the angle of every [`qiskit.circuit.library.RZGate`](/api/qiskit/qiskit.circuit.library.RZGate "(in Qiskit v1.2)") to the closest multiple of pi/2 (or to a random multiple of pi/2 if the angle is unspecified), while it skips every Clifford gate, measurement, and barrier. @@ -111,7 +111,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.ConvertISAToClifford ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx index 0ebb38050d3..e0c79f65741 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay # ConvertIdToDelay - + Convert `qiskit.circuit.library.standard_gates.IGate` to a delay of the corresponding length. Convert [`qiskit.circuit.library.IGate`](/api/qiskit/qiskit.circuit.library.IGate "(in Qiskit v1.2)") to a Convert [`qiskit.circuit.Delay`](/api/qiskit/circuit#qiskit.circuit.Delay "(in Qiskit v1.2)"). @@ -89,7 +89,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.ConvertIdToDelay ### run - + Run a pass on the DAGCircuit. This is implemented by the pass developer. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx index ec57aa6fff4..6883a79de78 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAna # ALAPScheduleAnalysis - + Dynamic circuits as-late-as-possible (ALAP) scheduling analysis pass. This is a scheduler designed to work for the unique scheduling constraints of the dynamic circuits backends due to the limitations imposed by hardware. This is expected to evolve over time as the dynamic circuit backends also change. @@ -103,7 +103,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.ALAPScheduleAna ### run - + Run the ASAPSchedule pass on dag. :type dag: [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)") :param dag: DAG to schedule. :type dag: DAGCircuit **Raises** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx index 37f8703ae96..cf13e5de38c 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAnalysis.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAna # ASAPScheduleAnalysis - + Dynamic circuits as-soon-as-possible (ASAP) scheduling analysis pass. This is a scheduler designed to work for the unique scheduling constraints of the dynamic circuits backends due to the limitations imposed by hardware. This is expected to evolve over time as the dynamic circuit backends also change. @@ -103,7 +103,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.ASAPScheduleAna ### run - + Run the ALAPSchedule pass on dag. :type dag: [`DAGCircuit`](/api/qiskit/qiskit.dagcircuit.DAGCircuit "(in Qiskit v1.2)") :param dag: DAG to schedule. :type dag: DAGCircuit **Raises** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx index c1e8b78ccee..c7426cedc08 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder # BlockBasePadder - + The base class of padding pass. This pass requires one of scheduling passes to be executed before itself. Since there are multiple scheduling strategies, the selection of scheduling pass is left in the hands of the pass manager designer. Once a scheduling analysis pass is run, `node_start_time` is generated in the `property_set`. This information is represented by a python dictionary of the expected instruction execution times keyed on the node instances. The padding pass expects all `DAGOpNode` in the circuit to be scheduled. @@ -93,7 +93,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.BlockBasePadder ### run - + Run the padding pass on `dag`. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx index bd160bb9dd4..59108504f16 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitInstructionDurations.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitI # DynamicCircuitInstructionDurations - + For dynamic circuits the IBM Qiskit backend currently reports instruction durations that differ compared with those required for the legacy Qobj-based path. For now we use this class to report updated InstructionDurations. TODO: This would be mitigated by a specialized Backend/Target for dynamic circuit backends. Dynamic circuit instruction durations. @@ -27,7 +27,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitI ### from\_backend - + Construct a `DynamicInstructionDurations` object from the backend. :type backend: [`Backend`](/api/qiskit/qiskit.providers.Backend "(in Qiskit v1.2)") :param backend: backend from which durations (gate lengths) and dt are extracted. **Returns** @@ -41,7 +41,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitI ### from\_target - + Construct a `DynamicInstructionDurations` object from the target. :type target: [`Target`](/api/qiskit/qiskit.transpiler.Target "(in Qiskit v1.2)") :param target: target from which durations (gate lengths) and dt are extracted. **Returns** @@ -96,7 +96,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.DynamicCircuitI ### update - + Update self with inst\_durations (inst\_durations overwrite self). Overrides the default durations for certain hardcoded instructions. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx index 261c35f5685..47e0cbef5a2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay # PadDelay - + Padding idle time with Delay instructions. Consecutive delays will be merged in the output of this pass. @@ -107,7 +107,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.PadDelay ### run - + Run the padding pass on `dag`. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx index 1735443239d..bbead795405 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDec # PadDynamicalDecoupling - + Dynamical decoupling insertion pass for IBM dynamic circuit backends. This pass works on a scheduled, physical circuit. It scans the circuit for idle periods of time (i.e. those containing delay instructions) and inserts a DD sequence of gates in those spots. These gates amount to the identity, so do not alter the logical action of the circuit, but have the effect of mitigating decoherence in those idle periods. As a special case, the pass allows a length-1 sequence (e.g. \[XGate()]). In this case the DD insertion happens only when the gate inverse can be absorbed into a neighboring gate in the circuit (so we would still be replacing Delay with something that is equivalent to the identity). This can be used, for instance, as a Hahn echo. This pass ensures that the inserted sequence preserves the circuit exactly (including global phase). @@ -244,7 +244,7 @@ python_api_name: qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDec ### run - + Run the padding pass on `dag`. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx index 58f7eb6f2c3..8f67e16935d 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.LayerError.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.utils.noise_learner_result.LayerError # LayerError - + The error channel (in Pauli-Lindblad format) of a single layer of instructions. **Parameters** @@ -87,21 +87,47 @@ python_api_name: qiskit_ibm_runtime.utils.noise_learner_result.LayerError ### draw\_map - + Draw a map view of a this layer error. **Parameters** * **embedding** (`Union`\[`Embedding`, [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)")]) – An `Embedding` object containing the coordinates and coupling map to draw the layer error on, or a backend to generate an `Embedding` for. + * **colorscale** (`str`) – The colorscale used to show the rates of this layer error. + * **color\_no\_data** (`str`) – The color used for qubits and edges for which no data is available. + + * **color\_out\_of\_scale** (`str`) – The color used for rates with value greater than `highest_rate`. + * **num\_edge\_segments** (`int`) – The number of equal-sized segments that edges are made of. + * **edge\_width** (`float`) – The line width of the edges in pixels. + * **height** (`int`) – The height of the returned figure. + + * **highest\_rate** (`Optional`\[`float`]) – The highest rate, used to normalize all other rates before choosing their colors. If `None`, it defaults to the highest value found in the `layer_error`. + * **background\_color** (`str`) – The background color. + * **radius** (`float`) – The radius of the pie charts representing the qubits. + * **width** (`int`) – The width of the returned figure. + * **code:** (*..*) – + + python: from qiskit import QuantumCircuit from qiskit.quantum\_info import PauliList from qiskit\_ibm\_runtime.utils.embeddings import Embedding from qiskit\_ibm\_runtime.utils.noise\_learner\_result import LayerError, PauliLindbladError + + \# A five-qubit 1-D embedding with nearest neighbouring connectivity coordinates1 = \[(0, 0), (0, 1), (0, 2), (0, 3), (0, 4), (0, 5)] coupling\_map1 = \[(0, 1), (1, 2), (2, 3), (3, 4), (4, 5)] embedding1 = Embedding(coordinates1, coupling\_map1) + + \# A six-qubit horseshoe-shaped embedding with nearest neighbouring connectivity coordinates2 = \[(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2)] coupling\_map2 = \[(0, 1), (1, 2), (0, 3), (3, 4), (4, 5)] embedding2 = Embedding(coordinates2, coupling\_map2) + + \# A LayerError object circuit = QuantumCircuit(4) qubits = \[1, 2, 3, 4] generators = PauliList(\[“IIIX”, “IIXI”, “IXII”, “YIII”, “ZIII”, “XXII”, “ZZII”]) rates = \[0.01, 0.01, 0.01, 0.005, 0.02, 0.01, 0.01] error = PauliLindbladError(generators, rates) layer\_error = LayerError(circuit, qubits, error) + + \# Draw the layer error on embedding1 layer\_error.draw\_map(embedding1) + + \# Draw the layer error on embedding2 layer\_error.draw\_map(embedding2) + **Return type** `Figure` diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx index 9017c52773b..822b10ee1a2 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError.mdx @@ -8,7 +8,7 @@ python_api_name: qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladErro # PauliLindbladError - + A Pauli error channel generated by a Pauli Lindblad dissipators. This operator represents an N-qubit quantum error channel $E(\rho) = e^{\sum_j r_j D_{P_j}}(\rho)$ generated by Pauli Lindblad dissipators $D_P(\rho) = P \rho P - \rho$, where $P_j$ are N-qubit `Pauli` operators. @@ -73,7 +73,7 @@ $$ ### restrict\_num\_bodies - + The [`PauliLindbladError`](#qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError "qiskit_ibm_runtime.utils.noise_learner_result.PauliLindbladError") containing only those terms acting on exactly `num_qubits` qubits. **Parameters** diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx new file mode 100644 index 00000000000..efb1a045508 --- /dev/null +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_execution_spans.mdx @@ -0,0 +1,33 @@ +--- +title: draw_execution_spans +description: API reference for qiskit_ibm_runtime.visualization.draw_execution_spans +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit_ibm_runtime.visualization.draw_execution_spans +--- + + + +# draw\_execution\_spans + + + Draw one or more [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans") on a bar plot. + + **Parameters** + + * **spans** ([*ExecutionSpans*](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans")) – One or more [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans"). + * **names** (*str | Iterable\[str] | None*) – Name or names to assign to respective `spans`. + * **common\_start** (*bool*) – Whether to shift all collections of spans so that their first span’s start is at $t=0$. + * **normalize\_y** (*bool*) – Whether to display the y-axis units as a percentage of work complete, rather than cumulative shots completed. + * **line\_width** (*int*) – The thickness of line segments. + * **show\_legend** (*bool*) – Whether to show a legend. By default, this choice is automatic. + + **Return type** + + PlotlyFigure + + **Returns** + + A plotly figure. + + diff --git a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx index d3c01120660..3838724c013 100644 --- a/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx +++ b/docs/api/qiskit-ibm-runtime/qiskit_ibm_runtime.visualization.draw_layer_error_map.mdx @@ -10,7 +10,7 @@ python_api_name: qiskit_ibm_runtime.visualization.draw_layer_error_map # draw\_layer\_error\_map - + Draw a map view of a [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError"). **Parameters** @@ -19,9 +19,11 @@ python_api_name: qiskit_ibm_runtime.visualization.draw_layer_error_map * **embedding** (`Union`\[`Embedding`, [`BackendV2`](/api/qiskit/qiskit.providers.BackendV2 "(in Qiskit v1.2)")]) – An `Embedding` object containing the coordinates and coupling map to draw the layer error on, or a backend to generate an `Embedding` for. * **colorscale** (`str`) – The colorscale used to show the rates of `layer_error`. * **color\_no\_data** (`str`) – The color used for qubits and edges for which no data is available. + * **color\_out\_of\_scale** (`str`) – The color used for rates with value greater than `highest_rate`. * **num\_edge\_segments** (`int`) – The number of equal-sized segments that edges are made of. * **edge\_width** (`float`) – The line width of the edges in pixels. * **height** (`int`) – The height of the returned figure. + * **highest\_rate** (`Optional`\[`float`]) – The highest rate, used to normalize all other rates before choosing their colors. If `None`, it defaults to the highest value found in the `layer_error`. * **background\_color** (`str`) – The background color. * **radius** (`float`) – The radius of the pie charts representing the qubits. * **width** (`int`) – The width of the returned figure. diff --git a/docs/api/qiskit-ibm-runtime/release-notes.mdx b/docs/api/qiskit-ibm-runtime/release-notes.mdx index 0a7c3865d45..3d2f557c734 100644 --- a/docs/api/qiskit-ibm-runtime/release-notes.mdx +++ b/docs/api/qiskit-ibm-runtime/release-notes.mdx @@ -10,8 +10,48 @@ in_page_toc_max_heading_level: 2 +## 0.32.0 (2024-10-30) + +### New Features + +* Added [`draw_execution_spans()`](qiskit_ibm_runtime.visualization.draw_execution_spans "qiskit_ibm_runtime.visualization.draw_execution_spans"), a function for creating a Plotly figure that visualizes one or more [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans") objects. Also added the convenience method [`draw()`](qiskit_ibm_runtime.execution_span.ExecutionSpans#draw "qiskit_ibm_runtime.execution_span.ExecutionSpans.draw") to invoke the drawing function on a particular instance. ([1923](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1923)) + + ```python + from qiskit_ibm_runtime.visualization import draw_execution_spans + + # use the drawing function on spans from sampler job data + spans1 = sampler_job1.result().metadata["execution"]["execution_spans"] + spans2 = sampler_job2.result().metadata["execution"]["execution_spans"] + draw_execution_spans(spans1, spans2) + + # convenience to plot just spans1 + spans1.draw() + ``` + +* Added a new method, `backend.refresh()` that refreshes the current backend target with the latest updates from the server. ([1955](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1955)) + +* Added [`DoubleSliceSpan`](qiskit_ibm_runtime.execution_span.DoubleSliceSpan "qiskit_ibm_runtime.execution_span.DoubleSliceSpan"), an `ExecutionSpan` for batching with two slices. ([1982](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1982)) + +* Each of [`SamplerV2`](qiskit_ibm_runtime.SamplerV2 "qiskit_ibm_runtime.SamplerV2"), [`EstimatorV2`](qiskit_ibm_runtime.EstimatorV2 "qiskit_ibm_runtime.EstimatorV2"), and [`noise_learner.NoiseLearner`](qiskit_ibm_runtime.noise_learner.NoiseLearner "qiskit_ibm_runtime.noise_learner.NoiseLearner") now has a `backend()` method that returns the backend that the class is configured with. ([1995](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1995)) + +### Other Notes + +* Deprecations from the `0.25.0` release have been removed. + + > * `optimization_level` is no longer a valid option for `EstimatorV2`. + > * Job methods `interim_results()` and `stream_results()` have been removed. ([1965](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1965)) + +* The `channel_strategy` parameter in `QiskitRuntimeService` has been removed. To continue using Q-CTRL in your workflow, please explore the following options: + + > * If your organization has an existing IBM Quantum Premium Plan instance: migrate to the Q-CTRL Performance Management Function, found in the [Qiskit Functions Catalog](https://quantum.ibm.com/functions). + > * To continue using Qiskit Runtime with IBM Cloud: migrate to Q-CTRL Fire Opal, the same performance management product accessible directly through Q-CTRL. You can [connect your IBM Cloud API key and Qiskit Runtime CRN](https://docs.q-ctrl.com/fire-opal/discover/hardware-providers/how-to-authenticate-with-ibm-credentials) to Fire Opal. ([1966](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1966)) + + + ## 0.31.0 (2024-10-15) + + ### New Features * Added Noisy Estimator Analyzer Tool (NEAT), a class to help understand the expected performance of Estimator jobs. ([1950](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1950)) @@ -21,11 +61,13 @@ in_page_toc_max_heading_level: 2 * Fixed an issue with ISA validation where a change related to connectivity inside control operations was not applied correctly. ([1954](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1954)) + + ### Other Notes * Fake V1 backends have been removed. ([1946](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1946)) - + ## 0.30.0 (2024-09-23) @@ -40,7 +82,7 @@ in_page_toc_max_heading_level: 2 * In a future release, `RuntimeJob.status()` will be returned as a string instead of an instance of `JobStatus`. ([1933](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1933)) - + ### New Features @@ -63,13 +105,13 @@ in_page_toc_max_heading_level: 2 * The `use_fractional_gates` flag for `QiskitRuntimeService.backend()` and `QiskitRuntimeService.backends()` can now be `None`. When set to `None`, no instruction filtering is done, and the returned backend target may contain both fractional gates and control flow operations. ([1938](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1938)) - + ### Bug Fixes * Fixed a bug where primitives could not be run in the session context with fractional gates. ([1922](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1922)) - + ### Other Notes @@ -83,27 +125,27 @@ in_page_toc_max_heading_level: 2 * In `Service.backend()`, “name” is now a required parameter * `Service.get_backend()` has been removed and replaced with `backend()` ([1907](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1907)) - + ## 0.29.1 (2024-09-17) - + ### New Features * Added logic to encode and decode `NoiseLearnerResult`. ([1908](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1908)) - + ## 0.29.0 (2024-09-04) - + ### Deprecation Notes * The simulator option `noise_model` is now deprecated for jobs running on real devices. `noise_model` will still be an acceptable option when using the local testing mode. ([1892](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1892)) - + ### New Features @@ -111,7 +153,7 @@ in_page_toc_max_heading_level: 2 * Added a new `private` option under `EnvironmentOptions`. ([1888](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1888)) * Added `fallback` option to ZNE extrapolators. ([1902](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1902)) - + ### Bug Fixes @@ -119,54 +161,54 @@ in_page_toc_max_heading_level: 2 * Revert a previous change to `backend.target` where the target was no longer being cached. ([1891](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1891)) * Fixed an issue where `Session.from_id()` would create a new empty session. ([1896](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1896)) - + ## 0.28.0 (2024-08-15) - + ### New Features * `ResilienceOptionsV2` has a new field `layer_noise_model`. When this field is set, all the mitigation strategies that require noise data skip the noise learning stage, and instead gather the required information from `layer_noise_model`. ([1858](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1858)) - + ### Other Notes * The V1 Primitives `SamplerV1` and `EstimatorV1` have been completely removed. Please see the [migration guide](/migration-guides/v2-primitives) and use the V2 Primitives instead. ([1857](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1857)) * The `service` parameter is now required in `Session.from_id()`. ([1868](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1868)) - + ## 0.27.1 (2024-08-12) - + ### New Features * Added logic to encode and decode `PauliLindbladError` and `LayerError`. ([1853](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1853)) - + ## 0.27.0 (2024-08-08) - + ### New Features * Added `PauliLindbladError` and `LayerError` classes to represent layers noise processes. ([1844](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1844)) - + ### Bug Fixes * Fixed an issue with using the aer simulator and local service mode with sessions. ([1838](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1838)) - + ## 0.26.0 (2024-07-31) - + ### Deprecation Notes @@ -175,7 +217,7 @@ in_page_toc_max_heading_level: 2 * Passing in `service` in `Session`, `Batch` has been deprecated. The `service` parameter is no longer necessary because the service can be extracted from the backend. ([1826](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1826)) * Since backend modules from `qiskit.providers.models` including `BackendProperties` and `BackendConfiguration` are deprecated in Qiskit 1.2, they have been copied into `qiskit-ibm-runtime`. Make sure to upgrade to the latest version, `0.26.0`, to use these classes. ([1803](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1803)) - + ### New Features @@ -197,7 +239,7 @@ in_page_toc_max_heading_level: 2 * Added `NoiseLearner` and related functionality, such as `NoiseLearnerOptions` and `NoiseLearnerResults`. ([1805](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1805)) - + ### Bug Fixes @@ -206,18 +248,18 @@ in_page_toc_max_heading_level: 2 * The options validation for checking if `zne_mitigation` or `pec_mitigation` are set to `True` when using other related options has been removed. ([1792](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1792)) * Fixed an issue where users were unable to retrieve job results if the python library `simplejson` was installed in their environment. ([1800](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1800)) - + ## 0.25.0 (2024-07-02) - + ### Deprecation Notes * The `optimization_level` option in `EstimatorV2` is deprecated. Instead, you can perform circuit optimization using the Qiskit transpiler or Qiskit transpiler service. ([1748](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1748)) -* [`qiskit_ibm_runtime.RuntimeJobV2.interim_results()`](qiskit_ibm_runtime.RuntimeJobV2#interim_results "qiskit_ibm_runtime.RuntimeJobV2.interim_results"), [`qiskit_ibm_runtime.RuntimeJobV2.stream_results()`](qiskit_ibm_runtime.RuntimeJobV2#stream_results "qiskit_ibm_runtime.RuntimeJobV2.stream_results"), [`qiskit_ibm_runtime.RuntimeJob.interim_results()`](qiskit_ibm_runtime.RuntimeJob#interim_results "qiskit_ibm_runtime.RuntimeJob.interim_results"), and [`qiskit_ibm_runtime.RuntimeJob.stream_results()`](qiskit_ibm_runtime.RuntimeJob#stream_results "qiskit_ibm_runtime.RuntimeJob.stream_results") are now all deprecated. ([1776](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1776)) +* `qiskit_ibm_runtime.RuntimeJobV2.interim_results()`, `qiskit_ibm_runtime.RuntimeJobV2.stream_results()`, `qiskit_ibm_runtime.RuntimeJob.interim_results()`, and `qiskit_ibm_runtime.RuntimeJob.stream_results()` are now all deprecated. ([1776](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1776)) - + ### New Features @@ -225,21 +267,21 @@ in_page_toc_max_heading_level: 2 * Added an `instance` property to `BaseRuntimeJob` which returns the instance where the job was run. ([1771](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1771)) * `default_shots` are now a supported option when using `EstimatorV2` in local testing mode. ([1773](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1773)) - + ## 0.24.1 (2024-06-18) - + ### Bug Fixes * Disallowing fractional gates by default, so backend target would not exclude control flow. ([1755](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1755)) - + ## 0.24.0 (2024-06-10) - + ### Deprecation Notes @@ -257,7 +299,7 @@ in_page_toc_max_heading_level: 2 * Specifying options without the full dictionary structure is deprecated. Instead, pass in a fully structured dictionary. For example, use `{'environment': {'log_level': 'INFO'}}` instead of `{'log_level': 'INFO'}`. ([1731](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1731)) - + ### New Features @@ -296,7 +338,7 @@ in_page_toc_max_heading_level: 2 * [`QiskitRuntimeService.backends()`](qiskit_ibm_runtime.QiskitRuntimeService#backends "qiskit_ibm_runtime.QiskitRuntimeService.backends") now always returns a new `IBMBackend` instance even when the same query is used. The backend properties and defaults data are retrieved from the server for every instance when they are accessed for the first time, while the configuration data is cached internally in the service instance. ([1732](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1732)) - + ### Bug Fixes @@ -308,18 +350,18 @@ in_page_toc_max_heading_level: 2 * Fixed nested experimental suboptions override non-experimental suboptions. ([1731](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1731)) * The backend utils method `convert_to_target` has been replaced with the [convert\_to\_target](/api/qiskit/qiskit.providers.convert_to_target) method from Qiskit. This fixes some issues related to target generation and calibration data. ([1600](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1600)) - + ## 0.23.0 (2024-04-15) - + ### Deprecation Notes * [backend.run()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend#run) has been deprecated. Please use the primitives instead. More details can be found in the [migration guide](/migration-guides/qiskit-runtime) . ([1561](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1561)) * In a future release, the `service` parameter in [from\_id()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session#from_id) will be required. ([1311](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1311)) - + ### New Features @@ -329,7 +371,7 @@ in_page_toc_max_heading_level: 2 * [`SamplerV2`](qiskit_ibm_runtime.SamplerV2 "qiskit_ibm_runtime.SamplerV2") now supports twirling. Twirling will only be applied to those measurement registers not involved within a conditional logic. ([1557](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1557)) * Session [details()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session#details) now includes a new field, `usage_time`. Usage is defined as the time a quantum system is committed to complete a job. ([1567](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1567)) - + ### Bug Fixes @@ -338,59 +380,59 @@ in_page_toc_max_heading_level: 2 * Fixed a bug with encoding/decoding `ParameterExpression`. ([1521](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1521)) * Fixed an issue where the [in\_final\_state()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJobV2#in_final_state) method in [`RuntimeJobV2`](qiskit_ibm_runtime.RuntimeJobV2 "qiskit_ibm_runtime.RuntimeJobV2") would not update the status when called. ([1547](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1547)) - + ## 0.22.0 (2024-03-21) - + ### Upgrade Notes * Modify `skip_reset_qubits` optional flag to the constructor for [`PadDynamicalDecoupling`](qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling "qiskit_ibm_runtime.transpiler.passes.scheduling.PadDynamicalDecoupling"). If `False`, dynamical decoupling is applied on qubits regardless of their state, even on delays that are at the beginning of a circuit. This option now matches the behavior in Qiskit. ([1409](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1409)) - + ### New Features * A new local testing mode is added. It allows you to validate your quantum prorams before sending them to a physical system. The local testing mode is activated if one of the fake backends in `qiskit_ibm_runtime.fake_provider` or a Qiskit Aer backend instance is used when instantiating a primitive or a session. ([1495](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1495)) - + ### Bug Fixes * Fix a bug that caused setting of `resilience_level=0` in `EstimatorV2` to be ignored (and the default value used instead). ([1541](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1541)) - + ## 0.21.2 (2024-03-18) - + ### Bug Fixes * Fixed a bug where `RuntimeDecoder` could import arbitrary classes. ([1527](https://github.com/Qiskit/qiskit-ibm-runtime/pull/1527)) - + ## 0.21.1 - + ### Bug Fixes * Fixed a bug where `SamplerV1` and `EstimatorV1` could not be imported because of an issue with how the aliases were defined. - + ## 0.21.0 - + ### Upgrade Notes * Circuits that do not match the target hardware definition are no longer supported by Qiskit Runtime primitives, unless `channel_strategy="q-ctrl"` is used. See the transpilation documentation ([transpile](/guides/transpile)) for instructions to transform circuits and the primitive examples ([run/primitives-examples](/guides/primitives-examples)) to see this coupled with operator transformations. - + ### Deprecation Notes @@ -398,7 +440,7 @@ in_page_toc_max_heading_level: 2 It will also be a required parameter for `qiskit_ibm_runtime.Session` and `qiskit_ibm_runtime.Batch`. - + ### Bug Fixes @@ -406,11 +448,11 @@ in_page_toc_max_heading_level: 2 * Fixed a bug where retrieving a fake backend through `FakeProviderForBackendV2.backend()` would result in a type error. * Fixes the check for ISA circuits to allow pulse gates and circuits that don’t have layout. - + ## 0.20.0 - + ### New Features @@ -428,57 +470,57 @@ in_page_toc_max_heading_level: 2 The sessions functionality will not change but note that `backend.run()` sessions prior to this release will no longer be supported after March 31, 2024. Please update your `qiskit-ibm-runtime` version as soon as possible before this date. - + ### Deprecation Notes * Circuits that do not match the target hardware definition will no longer be supported after March 1, 2024. See the transpilation documentation ([transpile](/guides/transpile)) for instructions to transform circuits and the primitive examples ([run/primitives-examples](/guides/primitives-examples)) to see this coupled with operator transformations. - + ### Bug Fixes * Fix assignment of instruction durations when scheduling circuits with control flow. Prior to this fix, the indices for instructions on inner blocks were not mapped to the physical indices in the outer dag. - + ### Other Notes * The `InstructionDurations` durations input is now also required for the constructor of `PadDelay`. - + ## 0.19.1 - + ### Upgrade Notes * Extend `DynamicCircuitInstructions.from_backend()` to extract and patch durations from both `BackendV1` and `BackendV2` objects. Also add `DynamicCircuitInstructions.from_target()` to use a `Target` object instead. - + ### Bug Fixes * Fix the patching of `DynamicCircuitInstructions` for instructions with durations that are not in units of `dt`. * Fixed an issue with the `qpy.dump()` function, when the `use_symengine` flag was set to a truthy object that evaluated to `True` but was not actually the boolean `True` the generated QPY payload would be corrupt. - + ## 0.19.0 - + ### Upgrade Notes * qiskit-ibm-provider is pending deprecation, and therefore will no longer be a dependency for qiskit-ibm-runtime. * qiskit-ibm-runtime is now compatible with Qiskit versions >= 0.45, including 1.0.0. - + ## 0.18.0 - + ### New Features @@ -486,30 +528,30 @@ in_page_toc_max_heading_level: 2 * Added `max_time` parameter to `IBMBackend.open_session()`. * Added a method `RuntimeJob.queue_info()` to get the queue information from the backend. This feature was transferred from `qiskit_ibm_provider`. - + ### Deprecation Notes * [runtime()](/api/qiskit-ibm-runtime/0.21/qiskit_ibm_runtime.QiskitRuntimeService#runtime) has been deprecated. - + ### Bug Fixes * Many methods in [RuntimeJob](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob) require retrieving the job data from the API with `job_get()`. This API call will now exclude the `params` field by default because they are only necessary in [qiskit\_ibm\_runtime.RuntimeJob.inputs()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#inputs). - + ## 0.17.0 - + ### New Features * Added a new method [properties()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#properties) which returns the backend properties of the job at the time the job was run. * [details()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session#details) has a new field, activated\_at, which is the timestamp of when the session was changed to active. - + ### Bug Fixes @@ -527,7 +569,7 @@ in_page_toc_max_heading_level: 2 * Fixed an issue where retrieving the coupling\_map of some backends would result in a NameError. - + ## 0.16.0 @@ -535,39 +577,39 @@ in_page_toc_max_heading_level: 2 Sessions are now thread-safe and allow for multiple concurrent interactive experiments. - + ### New Features * Sessions are now thread-safe. - + ### Upgrade Notes * Methods related to using custom programs are removed. - + ### Bug Fixes * If a cloud instance that is `q-ctrl` enabled is used while `q-ctrl` is not passed in as the `channel_strategy`, an error will be raised. - + ## 0.15.1 - + ### Bug Fixes * Reverting 0.15.0 changes to [from\_id()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session#from_id) because it was a breaking change without proper deprecation. - + ## 0.15.0 - + ### New Features @@ -604,13 +646,13 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * Removed storing result in `RuntimeJob._results`. Instead retrieve results every time the `results()` method is called. - + ### Deprecation Notes * Usage of the `~/.qiskit/qiskitrc.json` file for account information has been deprecated. Use `~/.qiskit/qiskit-ibm.json` instead. - + ### Bug Fixes @@ -619,34 +661,34 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * The `backend` parameter in [from\_id()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session#from_id) is being deprecated because sessions do not support multiple backends. Additionally, the `service` parameter is no longer optional. * The `circuit_indices` and `observable_indices` run inputs for [Estimator](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator) and [Sampler](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler) have been completely removed. - + ### Other Notes * Added migration code for running `backend.run` in qiskit\_ibm\_runtime instead of in qiskit\_ibm\_provider. - + ## 0.14.0 - + ### New Features * There is a new class, `qiskit_ibm_runtime.Batch` that currently works the same way as [qiskit\_ibm\_runtime.Session](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session) but will later be updated to better support submitting multiple jobs at once. * Arbitrary keys and values are no longer allowed in `Options`. - + ### Deprecation Notes * Custom programs are being deprecated as of qiskit-ibm-runtime 0.14.0 and will be removed on November 27, 2023. Users can instead convert their custom programs to use Qiskit Runtime primitives with Qiskit Serverless. Refer to the migration guide for instructions: [https://qiskit.github.io/qiskit-serverless/migration/migration\_from\_qiskit\_runtime\_programs.html](https://qiskit.github.io/qiskit-serverless/migration/migration_from_qiskit_runtime_programs.html) - + ## 0.13.0 - + ### New Features @@ -656,7 +698,7 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * At initialization, if not passed in directly, the default `instance` selected by the provider will be logged at the “INFO” level. When running a job, if the backend selected is not in the default instance but in a different instance the user also has access to, that instance will also be logged. - + ### Upgrade Notes @@ -664,18 +706,18 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper The old close method behavior has been moved to a new method, [qiskit\_ibm\_runtime.Session.cancel()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session#cancel), where all queued jobs within a session are cancelled and terminated. - + ### Bug Fixes * Fixed a bug where `shots` passed in as a numpy type were not being serialized correctly. * Fixed a bug in [target\_history()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend#target_history) where the datetime parameter was not being used to retrieve backend properties from the specified date. - + ## 0.12.2 - + ### New Features @@ -684,17 +726,17 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * Added new method `Session.from_id` which creates a new session with a given id. * There will now be a warning if a user submits a job that is predicted to exceed their system execution time monthly quota of 10 minutes. This only applies to jobs run on real hardware in the instance `ibm-q/open/main`. If the job does end up exceeding the quota, it will be canceled. - + ### Upgrade Notes * Job error messages now include the error code. Error codes can be found in [errors](/errors). - + ## 0.12.1 - + ### New Features @@ -702,7 +744,7 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * Users can now pass in a value of `default` to the `channel_strategy` parameter in [qiskit\_ibm\_runtime.QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService). Now, if an account is configured with a certain channel strategy, the user can override it by passing in `default`. * The Sampler and Estimator primitives have been enhanced to incorporate custom validation procedures when the channel\_strategy property within the :class:qiskit\_ibm\_runtime.QiskitRuntimeService is configured as “q-ctrl.” This customized validation logic effectively rectifies incorrect input options and safeguards users against inadvertently disabling Q-CTRL’s performance enhancements. - + ### Bug Fixes @@ -711,11 +753,11 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * Job error messages will no longer be returned in all uppercase. * The max\_execution\_time option is now based on system execution time instead of wall clock time. System execution time is the amount of time that the system is dedicated to processing your job. If a job exceeds this time limit, it is forcibly cancelled. Simulator jobs continue to use wall clock time. - + ## 0.12.0 - + ### New Features @@ -734,19 +776,19 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * There is a new parameter, `channel_strategy` that can be set in the initialization of [qiskit\_ibm\_runtime.QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService) or saved in [qiskit\_ibm\_runtime.QiskitRuntimeService.save\_account()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService#save_account). If `channel_strategy` is set to `q-ctrl`, all jobs within the service will use the Q-CTRL error mitigation strategy. - + ### Upgrade Notes * Circuits and other input parameters will no longer be automatically stored in runtime jobs. They can still be retrieved with [qiskit\_ibm\_runtime.RuntimeJob.inputs()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#inputs). - + ### Deprecation Notes * The `noise_amplifier` resilience options is deprecated. After the deprecation period, only local folding amplification will be supported. Refer to [https://github.com/qiskit-community/prototype-zne](https://github.com/qiskit-community/prototype-zne) for global folding amplification. - + ### Bug Fixes @@ -754,11 +796,11 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * Fixes a race condition in the test test\_cancel\_running\_job() in test\_job.py where job cancellation could not be performed. Refer to #1019 \<[https://github.com/Qiskit/qiskit-ibm-runtime/issues/1019](https://github.com/Qiskit/qiskit-ibm-runtime/issues/1019)>\_ for more details. * Previously we added validation when jobs were run to make sure the number of circuits was not greater than the maximum for that backend, `backend.max_circuits`. This limit isn’t actually necessary for primtives run from within a session. - + ## 0.11.3 - + ### New Features @@ -768,11 +810,11 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * There is a new method [update\_tags()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#update_tags) that can be used to update the `job_tags` of a job. * If `instance` is provided as parameter to [qiskit\_ibm\_runtime.QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService), then this is used as a filter in `QiskitRuntimeService.backends()`. If `instance` is not recognized as one of the provider instances, an exception will be raised. Previously, we only issued a warning. - + ## 0.11.2 - + ### New Features @@ -793,28 +835,28 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper options.simulator.seed_simulator = 42 ``` - + ### Bug Fixes * Fixed infinite recursion when attempting to deepcopy an IBMBackend. Added a method `qiskit_ibm_runtime.IBMBackend.deepcopy()`. * Fixed an issue where circuit metadata was not being serialized correctly resulting in a type error. - + ## 0.11.1 - + ### Deprecation Notes * In [qiskit\_ibm\_runtime.RuntimeJob.metrics()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#metrics), the bss field will be replaced by usage. - + ## 0.11.0 - + ### New Features @@ -834,59 +876,59 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper options.simulator = {"coupling_map": CouplingMap.from_line(10)} ``` - + ### Upgrade Notes * A default session is no longer open for you if you pass a backend name or backend instance to [qiskit\_ibm\_runtime.Sampler](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler) or [qiskit\_ibm\_runtime.Estimator](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator) constructors. The primitive will instead run without a session. In addition, you should now use the `backend` parameter to pass a backend name or instance instead of the `session` parameter (which can continue to be used to pass a session). * The first parameter of the [qiskit\_ibm\_runtime.Sampler](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler) and [qiskit\_ibm\_runtime.Estimator](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator) constructors is now `backend` instead of `session`. - + ### Deprecation Notes * Passing a backend name or backend instance to the `session` parameter when initializing a [qiskit\_ibm\_runtime.Sampler](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler) or [qiskit\_ibm\_runtime.Estimator](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator) has been deprecated. Please use the `backend` parameter instead. You can continue to pass a session using the `session` parameter. - + ## 0.10.0 - + ### New Features * Python 3.11 is now supported. - + ### Upgrade Notes * Added error messages in case the user defines unsupported values for ‘max\_execution\_time’. Previously, this validation was done on the server side. - + ### Bug Fixes * Added deserialization of the params of RuntimeJob.inputs. Previously, the circuits were returned in serialized format. Fixes issue [#829](https://github.com/Qiskit/qiskit-ibm-runtime/issues/829). * Allow for users to retrieve all backends even if one of the backends has a missing configuration. The backend without a configuration will not be returned. - + ## 0.9.4 - + ### New Features * Added methods to validate input options to `transpilation` and `environment` options. - + ### Upgrade Notes * When constructing a backend `qiskit.transpiler.Target`, faulty qubits and gates from the backend configuration will be filtered out. - + ### Deprecation Notes @@ -898,41 +940,41 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper Within [RuntimeOptions](/api/qiskit-ibm-runtime/0.25/qiskit_ibm_runtime.RuntimeOptions), `backend_name` is no longer supported. Please use `backend` instead. - + ### Bug Fixes * Fixed a bug where retrieving a job from a backend without `noise_model` or `seed_simulator` options would result in a key error. - + ## 0.9.3 - + ### Upgrade Notes * Added error messages in case the user defines unsupported values for ‘optimization\_level’ or for ‘resilience\_level’. Added validation checking for options given as input to `resilience`. Previously, this validation was done on the server side. By adding them on the client side, response will be much faster upon failure. The environment variable `QISKIT_RUNTIME_SKIP_OPTIONS_VALIDATION` is used to control validation. If set, validation will be skipped. * Backend configurations are no longer loaded when [QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService) is initialized. Instead, the configuration is only loaded and cached during [get\_backend()](/api/qiskit-ibm-runtime/0.29/qiskit_ibm_runtime.QiskitRuntimeService#get_backend) and [backends()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService#backends). - + ### Bug Fixes * When creating an Option object and passing an input option to `resilience_options`, this option was included in `resilience_options`, but the other, default options were removed. This was fixed, so now inputs are handled correctly, like other option types. - + ## 0.9.2 - + ### New Features * Added a new argument called `session_time` to the program\_run method and [qiskit\_ibm\_runtime.RuntimeOptions](/api/qiskit-ibm-runtime/0.25/qiskit_ibm_runtime.RuntimeOptions). Now values entered by the user for session `max_time` will be sent to the server side as `session_time`. This allows users to specify different values for session `max_time` and `max_execution_time`. * Added the method [target\_history()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend#target_history). This method is similar to [target()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend#target). The difference is that the new method enables the user to pass a datetime parameter, to retrieve historical data from the backend. - + ### Upgrade Notes @@ -940,7 +982,7 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * If a job is returned without a backend, retrieving the backend through [qiskit\_ibm\_runtime.RuntimeJob.backend()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#backend) will re-retrieve data from the server and attempt to update the backend. Additionally, `job_id` and `backend`, which were deprecated attributes of [qiskit\_ibm\_runtime.RuntimeJob](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob) have now been removed. * Added a user warning when the user passes an option that is not supported in Options. - + ### Bug Fixes @@ -949,11 +991,11 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * If an instance is passed in to [qiskit\_ibm\_runtime.QiskitRuntimeService.get\_backend()](/api/qiskit-ibm-runtime/0.29/qiskit_ibm_runtime.QiskitRuntimeService#get_backend) and then the backend is used in a session, all jobs within the session will be run from the original instance passed in. * Removed additional decomposition of `BlueprintCircuit`s in the JSON encoder. This was introduced as a bugfix, but has since been fixed. Still doing the decomposition led to possible problems if the decomposed circuit was not in the correct basis set of the backend anymore. - + ## 0.9.1 - + ### Upgrade Notes @@ -971,47 +1013,47 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper name = "my_account",) ``` - + ### Deprecation Notes * `backend` is no longer a supported option when using [qiskit\_ibm\_runtime.Session.run()](/api/qiskit-ibm-runtime/0.29/qiskit_ibm_runtime.Session#run). Sessions do not support multiple cross backends. Additionally, an exception will be raised if a backend passed in through options does not match the original session backend in an active session. - + ### Bug Fixes * `ECRGate` and `CZGate` mappings have been added to the `Target` constructor to fix a tranpile bug. - + ### Other Notes * Since error messages from a failing job may be long, we shortened them so that they begin from the last `Traceback` in the message. - + ## 0.9.0 - + ### Upgrade Notes * Changed the default values for `optimization_level` and for `resilience_level` in `qiskit_ibm_runtime.Options`. If their values are defined by the user, they are not modified. If not set, if the backend is a noiseless simulator then `optimization_level` is set to 1 and `resilience_level` is set to 0; Otherwise, they are be set to 3 and 1 respectively. * [session\_id()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#session_id) and [tags()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#tags) were added for an easy way to return the session\_id and job\_tags of a job. - + ### Bug Fixes * Fixed a bug where jobs that did not run before a session closes are not actually run as a part of that session. Jobs should run as a part of a session even if that session is closed by the exit of the context manager. * Fixes the issue wherein submitting a large job fails due to write operation timeout. - + ## 0.8.0 - + ### New Features @@ -1019,29 +1061,29 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * Advanced resilience options can now be set under `options.resilience`. See [qiskit\_ibm\_runtime.options.ResilienceOptions](/api/qiskit-ibm-runtime/0.27/qiskit_ibm_runtime.options.ResilienceOptions) for all available options. * You can now specify a pair of result decoders for the `result_decoder` parameter of [qiskit\_ibm\_runtime.QiskitRuntimeService.run()](/api/qiskit-ibm-runtime/0.29/qiskit_ibm_runtime.QiskitRuntimeService#run) method. If a pair is specified, the first one is used to decode interim results and the second the final results. - + ### Upgrade Notes * The default `resilience_level` option for has been changed from 0 to 1. In addition, the default `optimization_level` option has been changed from 1 to 3. - + ### Deprecation Notes * The transpilation options `translation_method` and `timing_constraints` have been deprecated. - + ### Bug Fixes * If a [qiskit\_ibm\_runtime.IBMBackend](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend) instance is passed to the [qiskit\_ibm\_runtime.Session](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Session) constructor, the service used to initialize the `IBMBackend` instance is used for the session instead of the default account service. - + ## 0.7.0 - + ### New Features @@ -1049,13 +1091,13 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * The [qiskit\_ibm\_runtime.options.EnvironmentOptions](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.EnvironmentOptions) class now accepts a `callback` parameter. This parameter can be used to stream the interim and final results of the primitives. * The `qiskit_ibm_runtime.Options` class now accepts `max_execution_time` as a first level option and `job_tags` as an option under `environment`. [qiskit\_ibm\_runtime.RuntimeOptions](/api/qiskit-ibm-runtime/0.25/qiskit_ibm_runtime.RuntimeOptions) has also been updated to include these two parameters. - + ### Upgrade Notes * This version of qiskit-ibm-runtime requires qiskit-terra version 0.22 or higher. The `requirements.txt` file has been updated accordingly. - + ### Deprecation Notes @@ -1063,7 +1105,7 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * Passing `instance` parameter to the [qiskit\_ibm\_runtime.QiskitRuntimeService.run()](/api/qiskit-ibm-runtime/0.29/qiskit_ibm_runtime.QiskitRuntimeService#run) has been deprecated. Instead, you can pass the `instance` parameter inside the `options` parameter. * Passing `job_tags` and `max_execution_time` as parameters to [qiskit\_ibm\_runtime.QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService) has been deprecated. Please pass them inside `options`. - + ### Bug Fixes @@ -1073,7 +1115,7 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper ## 0.7.0rc2 - + ### Upgrade Notes @@ -1081,7 +1123,7 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper * [Sampler](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler) is updated to return `SamplerResult` with `SamplerResult.quasi_dists` as a list of `QuasiDistrbution`. It used to set a list of `dict` as `SamplerResult.quasi_dists`, but it did not follow the design of `SamplerResult`. * The [RuntimeJob](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob) class is now a subclass of `qiskit.providers.Job`. - + ### Deprecation Notes @@ -1092,13 +1134,13 @@ Sessions are now thread-safe and allow for multiple concurrent interactive exper ## 0.7.0rc1 - + ### Prelude There are significant changes to how primitives are invoked within a session, and the options available to the primitives. Please review the rest of the release notes and the tutorials for full information. - + ### New Features @@ -1157,7 +1199,7 @@ There are significant changes to how primitives are invoked within a session, an * The [qiskit\_ibm\_runtime.QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService) `channel` can now be stored as an environment variable, `QISKIT_IBM_CHANNEL`. This way, when using Runtime Primitives, the service does not have to be instantiated manually and can instead be created directly from environment variables. - + ### Upgrade Notes @@ -1180,7 +1222,7 @@ There are significant changes to how primitives are invoked within a session, an * Since some accounts have many runtime programs, caching a list of all programs on the first call of `programs()` has been removed. Instead, programs will only be cached up to the `limit` given, which has a default value of 20. - + ### Deprecation Notes @@ -1198,17 +1240,17 @@ There are significant changes to how primitives are invoked within a session, an options.transpilation.skip_transpilation = True ``` - + ### Bug Fixes * Fixes issue [#428](https://github.com/Qiskit/qiskit-ibm-runtime/issues/428) by raising the minimum required `qiskit-terra` version to `0.21.0`, since latest version of `qiskit-ibm-runtime` is not compatible with `0.20.0` or earlier of `qiskit-terra`. - + ## 0.6.0 - + ### Upgrade Notes @@ -1225,17 +1267,17 @@ There are significant changes to how primitives are invoked within a session, an * `IBMRuntimeService` class which was deprecated earlier is now removed. Use [QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService) class going forward. - + ## 0.5.0 - + ### Prelude This release leverages the API and Queue enhancements to become more runtime session aware. As a result when using the primitives (sampler and estimator), runtime jobs in the same session will skip to the front of the queue, thereby speeding up the runtime session, once it has started. - + ### New Features @@ -1248,7 +1290,7 @@ This release leverages the API and Queue enhancements to become more runtime ses backend.service # QiskitRuntimeService instance used to instantiate the backend ``` - + ### Upgrade Notes @@ -1305,11 +1347,11 @@ This release leverages the API and Queue enhancements to become more runtime ses * [qubit\_properties()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.IBMBackend#qubit_properties) will now return a sub class of `QubitProperties` called `IBMQubitProperties` and will expose anharmonicity in addition to the t1, t2 and frequency already exposed by the `QubitProperties` class. - + ## 0.4.0 - + ### Upgrade Notes @@ -1394,55 +1436,55 @@ This release leverages the API and Queue enhancements to become more runtime ses result = sampler(circuit_indices=[0], ...) ``` - + ### Deprecation Notes * `IBMRuntimeService`, `IBMEstimator` and `IBMSampler` classes have been deprecated and will be removed in a future release. Use [QiskitRuntimeService](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.QiskitRuntimeService), [Estimator](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Estimator) and [Sampler](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.Sampler) classes instead. See upgrade notes section for a detailed explanation with examples. - + ## 0.3.0 - + ### Upgrade Notes * A new parameter `channel` has now been added to `qiskit_ibm_runtime.IBMRuntimeService` class and also to methods like `save_account()`, `saved_accounts()` and `delete_account()`. It can be set to `ibm_quantum` or `ibm_cloud` to authenticate to either of the two different channels through which Qiskit Runtime service is currently offered. `channel` replaces the `auth` parameter which has now been deprecated. - + ### Deprecation Notes * The `auth` parameter to `qiskit_ibm_runtime.IBMRuntimeService` class and also to methods like `save_account()`, `saved_accounts()` and `delete_account()` has now been deprecated and will be removed in a future release. Please use the new `channel` parameter instead. - + ### Bug Fixes * Fixed [#291](https://github.com/Qiskit/qiskit-ibm-runtime/issues/219) where passing a single `QuantumCircuit` to sampler or estimator primitives was throwing an error. - + ## 0.2.0 - + ### New Features * `qiskit_ibm_runtime.IBMEstimator` and `qiskit_ibm_runtime.IBMSampler` classes now allow you to easily interact with the `estimator` and `sampler` primitive programs. Refer to the examples in the respective class doc strings to learn more about how to use them. - + ### Bug Fixes * Fixed a bug where [qiskit\_ibm\_runtime.RuntimeJob.wait\_for\_final\_state()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#wait_for_final_state) would result in a NoneType error if the job already completed and [qiskit\_ibm\_runtime.RuntimeJob.status()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#status) was called beforehand. - + ## 0.1.0 - + ### Prelude @@ -1452,13 +1494,13 @@ This new package is built upon the work already done in qiskit.providers.ibmq.ru qiskit-ibm-runtime is not included as part of Qiskit meta package and thereby you have to install it separately using `pip install qiskit-ibm-runtime`. - + ### New Features * `qiskit_ibm_runtime.IBMRuntimeService.least_busy()` will now allow you find the least busy backend. - + ### Upgrade Notes @@ -1517,37 +1559,37 @@ qiskit-ibm-runtime is not included as part of Qiskit meta package and thereby yo * `qiskit_ibm_runtime.IBMRuntimeService.run()` method now accepts runtime execution options as [qiskit\_ibm\_runtime.RuntimeOptions](/api/qiskit-ibm-runtime/0.25/qiskit_ibm_runtime.RuntimeOptions) class in addition to already supported Dict. backend\_name, image and log\_level are the currently available options. -* Final result is also streamed now after interim results when you specify a `callback` to `qiskit_ibm_runtime.IBMRuntimeService.run()` or [qiskit\_ibm\_runtime.RuntimeJob.stream\_results()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#stream_results). +* Final result is also streamed now after interim results when you specify a `callback` to `qiskit_ibm_runtime.IBMRuntimeService.run()` or [qiskit\_ibm\_runtime.RuntimeJob.stream\_results()](/api/qiskit-ibm-runtime/0.30/qiskit_ibm_runtime.RuntimeJob#stream_results). - + ## 0.1.0rc2 - + ### New Features * For convenience, you can now set the `IBM Cloud service name` as a value for the account `instance` parameter. If you choose to set the name instead of the `CRN`, the initialization time of the `qiskit_ibm_runtime.IBMRuntimeService` class is slightly higher because the required `CRN` value is internally resolved via IBM Cloud APIs. - + ### Bug Fixes * [qiskit\_ibm\_runtime.utils.json.RuntimeEncoder](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeEncoder) and [qiskit\_ibm\_runtime.utils.json.RuntimeDecoder](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeDecoder) have been updated to handle instances of the Instruction class. * Fixed an issue where numpy ndarrays with object types could not be serialized. [qiskit\_ibm\_runtime.utils.json.RuntimeEncoder](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeEncoder) and [qiskit\_ibm\_runtime.utils.json.RuntimeDecoder](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeDecoder) have been updated to handle these ndarrays. - + ## 0.1.0rc1 - + ### New Features * You can now pass `instance` parameter in the hub/group/project format to `qiskit_ibm_runtime.IBMRuntimeService.jobs()` to filter jobs. Currently only supported for legacy authentication. -* You can now use the [qiskit\_ibm\_runtime.RuntimeJob.interim\_results()](/api/qiskit-ibm-runtime/qiskit_ibm_runtime.RuntimeJob#interim_results) method to retrieve runtime program interim results. Note that interim results will only be available for up to two days. +* You can now use the [qiskit\_ibm\_runtime.RuntimeJob.interim\_results()](/api/qiskit-ibm-runtime/0.30/qiskit_ibm_runtime.RuntimeJob#interim_results) method to retrieve runtime program interim results. Note that interim results will only be available for up to two days. - + ### Upgrade Notes @@ -1555,7 +1597,7 @@ qiskit-ibm-runtime is not included as part of Qiskit meta package and thereby yo * When uploading a program with `qiskit_ibm_runtime.IBMRuntimeService.upload_program()`, the program description is now optional. * When printing programs with `qiskit_ibm_runtime.IBMRuntimeService.pprint_programs()`, `backend_requirements` will now be listed. - + ### Bug Fixes diff --git a/docs/api/qiskit-ibm-runtime/visualization.mdx b/docs/api/qiskit-ibm-runtime/visualization.mdx index 25faf46d415..e1f16ffd8ce 100644 --- a/docs/api/qiskit-ibm-runtime/visualization.mdx +++ b/docs/api/qiskit-ibm-runtime/visualization.mdx @@ -20,5 +20,6 @@ A suite of functions for visualizing qiskit-ibm-runtime’s objects. | | | | ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`draw_execution_spans`](qiskit_ibm_runtime.visualization.draw_execution_spans "qiskit_ibm_runtime.visualization.draw_execution_spans")(\*spans\[, names, ...]) | Draw one or more [`ExecutionSpans`](qiskit_ibm_runtime.execution_span.ExecutionSpans "qiskit_ibm_runtime.execution_span.ExecutionSpans") on a bar plot. | | [`draw_layer_error_map`](qiskit_ibm_runtime.visualization.draw_layer_error_map "qiskit_ibm_runtime.visualization.draw_layer_error_map")(layer\_error, embedding) | Draw a map view of a [`LayerError`](qiskit_ibm_runtime.utils.noise_learner_result.LayerError "qiskit_ibm_runtime.utils.noise_learner_result.LayerError"). | diff --git a/public/api/qiskit-ibm-runtime/0.31/objects.inv b/public/api/qiskit-ibm-runtime/0.31/objects.inv new file mode 100644 index 0000000000000000000000000000000000000000..a31b4e334a77ccbac2687c8674d9194a5ab15a8e GIT binary patch literal 59437 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

fYLC%}o4dmRg9{41pVZx-6 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�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 D2m?p* delta 56562 zcmce-XIK+m-}W0Iga83U4+u&(^j<}z3j~l}L+`x{f*1%$2k9N@y-JZTy%*^SNbjH^ ziXzzd=yl!ib3b3+V}IDk{;($Hn3**>`OjLj&htm_EZ)pCUP89WlfZ@5yWaMCc6%Et z_E+)k45Z3f*HS`l70}eh<7+z5wmm*HDZ`t$KetOUlkBsJERynDQ{prg>~jBN_V%&Z z@2~7n+!D{(Fy6H{FyD3WVJe>Uu_&ztNq4==IAD^#8hY|(;k-?{I-6JOa?vG1$D}UD z<;iheo7r*g%Iy{3#=$!q8D~3J^Y6cM8SwtueM|B7epUNvC+4{0dNJkvO03Lf_2&@+ zX)u)){w}Mvs{QGncKE@1MvZ&bLoV~Zqly^spR zSsJjKW99@t?eB>299fHcShx1e$ECMzr@Uh>@B2=d!SK{wsh_7g<|m&$azjQu=eIAq ze_q|Vf3Ws`D8}xEzkOj#$C|gV`1?nf$8Y3s%_anT8@$1sT^;EkH9$x&`(oZPdol}itu(gAu zY-jjq*)O!Og{pv?qN<-XL*%%t^rxrVzXRUhzW*WXn5ttjI`PuV?D$;IB}8>L;k$Rs zn}eUu1eoTxA%5~x-|HsQF%qY4ss#GeH5m=E2QH@?*O-daM{8}8uOiL^)|*YgRIGR1 zx_%hA8?(JHe2MtV*MZSJ*zv$WU42z&UN6WOu|XpBYOM`(OU1m;z>7GXS0e=6@+R+O zO9}6HK$j#j{7rgb_gLxm!Rcen)6+`^gidVdO&tTC*Zz+4Sx14#`TVyZ^BozAi0BW9 zZ=W^=HGang{swnL?cQ}o&YjoaU+hS)#3Qc9I}7hze6TI72{TC)2qHNPFTtmAk@ojR zWH+*7voLGBbq68Et4kwHJuqW|-%CGHK|_ag<$-h0m%hexZd)C8Ra1$1+Fe&&de{wp z>FZN_GG|Pg-14nvY^CnytJ6pO?dUf4NAqi8de{Ms#?$_!jK>|vKPn(Md@Lv0EBx{< zUHv3k{B#>bF1^aLr?bWKeoH?+=9??JysGRh08vL&zxd($P>+c&H578CGbJh0# z6*qj#Ofedb9GmaEb6=#qv;1~F@i1ae$MsiLJj4OKBb zTtVm9^pk?x6}QXzmW^^@p(jChCQ;vA1#r^7lMgrhG-O%@eXY!k;Z|DzCZOWKUw3k# zBmQ>%o2W$Kr)a{B*Rj95ADEH`KtmTNFag&lKi_@8Natyo_rULZsn51u564#y!8%hv zkCXWmZYLY4AqEdskNG*fakQt^S;EDW*H{_fp=k>+wMD9rv=bwc($h;`ly#ejiL4qD&t9i;{^wpRn8ajk{sDZL)TQ z=JV;4@9OP#)79LQ%H`Yldu7vws!`JOd>)GhW-rYS0tEHAQgcZ-!qb%TD z0+(ekrY;Y6E$4q8bzFD4_oZ7C^JqzYGMlZJI8Cg&18WsK+qxj^y_NUWeX8_y>bt$o zium^WMBPD9<88h1N?v5LW^Cu}M*VGS!j>;JnZM71)|NVcp6?K5Y`~1gexFpV)j7(w zjws`uVfNH$`1mmh55M(a{sXUhhJZ^8&pMp=aVdG^GQer#a`4(RCgyR(*_Q!*p_~3< zWf-TgBQbQ4ciAmf(jkFAfNq<9o_Kh?9b7gLT-EZU=<$~AK9=H_b~bqU)8mBlTB<+( zHBF1ze0EB9;kw$d=S~|Rq+d+!dRlsZ%bn<$#N-U>oM|Y%qX_bEIjueHzx&}eu=zFx zY<{dC_IEVO;~cDL-tS!5uvSzNnElAL_`P=0`H6_y!TE?_rlikTO` z=XqNMQr(eE$1)OFApmL5zWzx1I*+L1KBV0@ z_bn5gnp~@jr5#xti}3pvG>D1tt2*VD?%X-$k?xc~KW z0h18m4A~)`|sCw@en=i4thX&fc6ujEbGMh-cGSYf6i`j z>^te^x_Mx7wc6l0l-68HcP*M_ z*LBVyJk@&qT{h?APz$!~{L<6D+wfQ9FS{$$&w0#>Z<$W()9t#J>^B=%3y(fev|y^M zPN$a62j>jb+rM%JN}poBrhii$`&Dx5HOGgW;&+~-(|x2qtOkfZaWpFUFW-cFCL)A$I#1M=?H zk4S6P_Bs{st<-dqOlf5uq~ZkRwQGE_(w^}gdAl72s+ zyRW@xsTt{&qME!pT%Pmh?2g2(6;-dMhL~NCCwQaafkY01I%(cLsi$>gFQ-LQi`rPU z<4uF41QXva+6Wq)sfwm7C%Ej7bvdl9z1_KNW8k{|%HWON^Nk~qMbZ;r-|i$ui{ZRcrkF zU)g-MSZ@a?xwp;HRks4O_12e;`t;0GtW}=m(u4;61zM}%eM>sB0I@~ z4oFz)@GQ=5KhE7eUB#%Z%LH#+okNDQ#IWd)Z3S77f3eQY$=%7i2OG|JyK_%{(AnzG zLaT#L#x7>J#IJ`kmIxQS9`5@ldH*~|x8ywz7RSk2C2nywxa(GTfa4zZ_}=B| zU7Ph0^972>EZ0iuyIYk zxM+qsl6jUHr*>8?;KVmINs_0iT#hFcuF7Mntj)ueZ_G1TWyM40;l$(Vb4=u;=D<=W z>R(-E6T?_&XCjC3hP$GCa-2*+K4?L!68bO`@K%Zm?o6=>Hn=$(|1fB(yeS}to79A( z<@p#c?;r&cuiPOyueK%~uVrgwYgk`pD>1zoIZz7VbJxH%9 zi{JoWTz_c0axYiAGK+FM6vw$eWewF5nNS&%Sy&yjoPw!E!J6t(=lKmWqe)FMTjj4} zwxp*Zz9I+vK0o?0I>g~HuaA!`*^O5f$=6mC$yHY-1&Wt28ggck%9k;SlzJ4by$(g6 zQrpNFUDHU}S}jCbSS3WCQaR3ASuxHURvv@Emc?AvmkKS{%r%dyw8NMs+haqx+Q9{g zb})zt(@x2I-Int3s7+xeYQayzrpQjzqr50H29cFvf;-psj{IiH9`(l`X~gDiYom%V z)loLs=m;BFcVzk7`riA|<5uND_w4x>745B*@l~ynjM=RtJ&~>8t*tF`XvG$Hlcs25933XyXQG;|6Hs25933XyXQG;|6F0v@l>FEXEBG$L$|+j$Xl-k6*=xoV)@T z9KHgBj$cvo9=`&#dG)`v0S?P@1GMp71+-cHR~w*zm}(0fOr-_TrsZF4Uj3^LaH9B= zSCNb-uSR-+6K@r)0@|$p)durdoY}hqIq*Z7$xJlP+BNiSw^f6JTXY+j%AwPJrtGn%vPV ziSUb0Z&XIcWfok?LT6p0WS20mQNSB&g&Eg0+$Gm=xp~)c;B%(Jf@@~jv@4nXw5!1F zMOXF?-*!=nwKQ3UwKM^bwKPV`wKR~-T3VmtTG}U$wKSyU%j@_^m-z_@sqZ{+)SN5I zqTS8Js>o**_r-?SR#h?Z^JR}-g)spw_*nGjMn}#)qcv)k3yf>>ijW>~CeJl$GMhDO zS_E)*DIXJDCf`;3SQ>)R&7?QaPyu(sDXfO~0~wB$*X%UGYj%vl&)Z?}F|o<_HL=<9 zHBpf9HBmiH&AzA5GN_>5GH9dJ!iKBgQsSZ3GKf}e8FbJD8qEf7Kw933{2F}H)svpO zsN)qs8K!E5Il^UynSfeXwcvbf!TOs?@-SyZn-kNa>{!the3>VpvZLnXIEF zQmV5hovF1YMb|1q*J}oSbZatq7Z0L~2aJcNJB`DGn~mk*)yC1o#m3Q#ImW8?DaKZZ zO=EYZ>d7c>3eUbNRfMXP@>q`Yx<-$&=aS5(nkvL0wF5 z(x8PJ&~6xDC6jc13cu^p#_$v%)WDJmA)%W!liZ1?Q`}^1(`g>XT-H&_t!lb?cAm%z z{rW?@n$3cX6?$b)7jHUr)1-sKs_0HZiit{bKuc0&f;;sCevdS~MGv9y#dEs-Ff<{n zaT_^-fj55a_5l%GbCwETSivQZL7Ey&`;b=6B+kS=cqISqZh%xw(P*c0aQjThkg{VJ zSH|n{;hHSBD{j(~Ya;s5ODbgfMYi>Yo4vLEZzJYB*NpX0y_<$Io2t`=BWBYL{9g6J z=lo&#@Crhj0;$J_lwzc};%^nlF>+i=;{$<8 zG1##oY`%fJ71;-eWRXh;LIjRcLOpduaF1^Bq`{M7MNmnxqQ~cl^?uhr$DFF_;UN|Y z5lK0A+rBo8o|=gvVRH#Wun*)Ji3#Z;)wl2RwbKtWH?~_z|N{gP&3-f{Ld2@x}=Desg)2SCtr^Kw+uT(x{ zHf+aig{>1q+gFHTDT^_1UR6G9y`($o&R{QN>n_H7D~p_HD;6qvWfmc+zhq0PxL^y_ zoO|YfLy-pIe~-oxEJ6df;Gszl+_Sqe>&c|0>&cWk>ya3&?;$`x@6KeP?aoBE;KsBv z*pmNZuhTuR(mL+s|NYR6`M-?K|9=e4nE%Vz{QvFH{I)Si!<=-Z+`Ma2evALc5%s}# zvq>Sw6Yd@ruH#OFTp9F`l{W_}4u#CYj?&*IHf<1j`%1dr1-#e>qdghSE=ES?!KUTD}G8Sk*s zJ^zsU&crq|9S545&hJx@E{-fomqizwg&XZdV}DVyZ+KAzlUgy~V75FXMJ z2r;!ODYaC}tsFcKtcOM@S08O0lF(i%g`GP}SIdx`ta5rA+A!_a)9x`eEos)DBgh@1 z;AptLxl$jjHDHN@TiK5*mlAz5sv3Oqpwp(bk#BOr7%a=?%{X8Myk zYH3m#!7q;0xeHlb8`xQSaEe%o$@NvK;TdU7SJ4?w(EO|>sM{~X3yto|uLl&C>^tJz zN|%Y2%=(H-q|0(jq)IYVOesrGr+T}76ne(OV_nq14fbl3u~tn8tZ5Uh-cT5pr6Wuk zt1&@es4_v{st^nBydQg1j*%1|t$9PGLf9W$(AEdTaqbIaMD$TUAMK^AdEA>ah3p-e zc1-p2w_srxbtuleih(CxnDiwDZIIIzT~lwqOCvI4TK)jcmnUq{!9zBX=Kk`>^&K@8 z&dw1g_r!@`NXZULl9P7e`rDOdl-t8LHxI}mW&6CEIY=nzxeq7CSm3Sz-I9dp+EMEe zhZtVps%R)E>J_5)?knY<<7Q>K>}DuPwK?U_>LOS*=5dl@Ok0=?>ZK6rUEMv z)0@E^(|fBH{D^gO?(y$W6{W&Pw_=7LA2tZn)=daL4;3Ak%8~2{o8gT@-TL(@LBu$G zOE-(jbJ{UHT*nE+7GJ!eN-bAI#a(H}iK-pu&O_EtJi`WnXFw#yz49ZZ+?nM_wfF4$|L zee!xOQ#WvvSV#!B6=hi*K5?+{A6FE6NGUa_)`PU0EJAQAdtqAz1VV&$P@%+pLLq21 zk@{1<^?124{)6Zh{sW!kX^-jaX~tk8fie`G0A4<)0G@vv%Ujy!g}DMrX@e9UVc-tC zQI%o8gJ~{g^7!0LU{+Zy7 z@6-J=!Q0|FGC}bjHGK#i4UvS7mT2x`d@GS%^8egn4yEHV{7KG3z#V4eYZF!cZG;>` znFQ(YSEi#jQ=wz;RiUFaR5iw$bwxdEDpsNHDrU+bC}t~|EPjRoEfkNYzblrN*(;U> z=J#^HLfCCmPtqc+K@7SulBwPP-fB9b8p5 zcJLrm=@ay=p(itRO1P>t5Xb@r1R@8I2VrUHlP%d0IwsGno+k(6$TnecKub?`I=8=< zI%r;~zbxF!PQq|Bi|zTT4l>X!Dm#);9~^#A0;#_>Wjrc9#YSuUc=MOB;TkBlc(Q;> zw%9?V-RfKA{;1xrrw|*x)e%Owpl`3sjGH;AmmIBI-_H#BDCMi4-`aPPV@x%Q+L8lB zoQx_|?-~sm%GDIxq_a?0yk-vD?6i_%?-;Tm7#As>3&1!RZ+0yr;)!ZF8q3^E;Lk+t z98aAlY>F3BCRZvssONO83%ARLG&R-Y3fhZ6YXf|)Ccl#%l41a##8mlNlp!0HgbfFk z1cFB-LeuO*g5dH~j2EXIe*h=h2$oZeKYGjxnlvWZlQqWgP&lT^U&-km*}&<&+0H5V zv5&K~2s1Xu+9GYhT2dnz&R#1BuC67=GS+EJmDXuDvDa%$7S)r>m+7r@o1A5{@KpW0*LLH3_XM7*tC5A#BMH2lHN;IZ97d^+M%hu#C{d+4Qvw~{7bh;qd#qzED1N1W9!<=s zoLfk&miM>=w%BAJ>$}FB&VEWgig?yCz&_T=CW<~W#hzo&lAwA)F~T*MdJm7f*@V@> zydk}+9yq9kP-5i_c6857*cL8X5h+cpWF6HpW#mv?;g-M;n;o`{Vg~o3G2Bn0JVngz zxR?kwDt&G0)O3s31~f=#cMq4c93zk(60jj8T_MW1Oy3gVnnyEufJ<5}!&jh78=#`- zFoVxcAln{1R55$g|I~&&g)cF(2-$_AN1yOewB1gX_|gs?M!i+!RvtFPJ+k_m6s^~k z?$cD=6^7gV0T*@Vg}PDx4h2y;Hfw+f_=QAKb`gsweClE)+dX50m4@(HVxHvQI{ftO zK~QzKe*F#7{(Sh_4~@_D?P8iE@nV|%R(|36ou7n=j%{hWTxBe5Tqn{=Tx~3xszc!D zYNlX(7xw9DXFCgB=R){Tr^22RCz(xkrxB$uj#I9tweqSd?9j=0cCcZT5~w$H$V2Vv zkj13`kc*PH5>}(KJ#>eT2UCZG_w$LZOakj3Zi)*#O)G-oanydZ+TroYD*;CSXaQ!V znZQt};Ecj0slB51O$d?iUDmI1GekochWO$B3%{Q|k-Js|5zNsriFb(+oLlznFf?RZ z41Nr=Kp$qfw+NGcXCZ`%W~3Hi?{?I=H#T1GgeM-HZZ|B?cBvG@!ZAa zR@|k@qTCR9B5oU^b*=%c2Ce}~f6{sPiv^VLp?PNai1YBaCuthjL!~O-{-W=^{qibx z_=uxu!_6(e8w(+{2-Pqn^0jayI@PF24@y2!>)t)XQD(Y^r0`iA{O8AGM7QKJXc4_x zv_yuvsoIs|%l+Te+Tl7ZmVL8!^N9MC zh^b^d?Vo9FZ35`>jS*sW#t5!EKgk$SC&X9v9`<}ZZTz&QvbPc1IwZu{FfPOzJKc!9 zrT=C-!O5L)G%*}}UYJkDx?ux{t_c@mfN3p>s2)r%Wf6rPmBHJx0Fw~b;FFM@K}evS zP}e`x8gu3JuG8!3U7^`&uloIIW{d0TVlL7dP%!fh2$u!>@3;@zTi&O@=-j8!irLx{|N=fo}$h(j!`pN`>3PXZ4@k5|8WF? zsFhWy()Cd%uwv_E<2KsiNfaP*$C+}i*rZBoHVv~#F~w^7nBs!;a!JnaO{EkU#?XJF z9)173Fby?RpA-YCjE}*9!=h18Qov30AUeezjKYFGDwh>fWl|J*KC_<7jd#wm5@PH$ z6M`lf$85Fh$AGJ~V_2IsVnF$-sJ1STRS2>vzY1OG+$9-a*Ou&DAR-3If zS;U^53?=5sj#1`=KJJCIy{>kbEpJ$oXHew%$Jr!bC{cbA9aS9B|G{H0qh4`Hog}R$Ls$W99 zIpv7bl(DqjMi%${duQ6smU56e@=>om;={Q5X%n`ApOP80Lu0GphNc0J3yb{U*X9fND_>nVL_Bk(gF=pygr^3MXB3!YW)%96GsLhx=2k`~ zK0K{pc9>F-9mFWWj#SBynh|@*jkFkaq0A(9W|sV zs>H{;b;U#TTD3t<4H2s}fryrwfaXhbZwIC~-l-s_hOGkE#T-+m^KeZ>Jkq$oa&GNp>beDX|`(wRo*J`H(h6g=&!O-8^2`( zYcA~Vnzb$CU7%G{2GFYPDQI>^TQq5eFnWv%jE)|fH;I09&QoqL!SGslo)2*V+-jko zF*-A2JTDKYcwTDGe!x{|C*n1HJ1+ahjWCSdJyTB1Ju^((9Ul|Dy-q}mer-fL^V*19 zwVRfD0cdhPZ1CP5HeAEr<%`7=&OO!~Su&m+oL&+1kfsz`38aXQr%^|<=j)>P59g^4 zGp3a^Tt6BB3tXek$wP zTY?Sj1^A89LG&)Bh55dwgP^+3JS|5YLm+)E=nu5kj0fff3?*To59r* z56yQa9=Gj7+q2xi*R?j^gy7(i)}F5Z;;K1<;I3h&Nx&&Njpwt@E`*WkM$Mk`Qf%8p zE^EDUS1C_pK+%t5j#_<)j|$z1uTq?{p}OOuWN@r&B+a{(1Y+mrgk?#zcaB;%Na4BY z;0}>1%;5bp0v6pUpzC92&08`)bfHoH3a^NcttzCCzUD2wj_{>K!fD^WS_&lF@{0S$ zD^5)NCEYg1p2!gDm2<3;qCxD3y+($r76`6ucIc(}f_+>;>lj_3ZH$PG5Uw-q(!+oS zR8d0&ef~t)cxq6d?S^0&`6rhB0Qwio3{-G11y!E_p~!&bw=$+|{fBsX?z!O(y5ezB z_X2go97>r~gw*7jS<;7W7P;aIGPLPFQD$R=6|l^XktsiM-&1L1Bp)x<2t->gheRoz)rsiG1g>3 zAf6}vm-m)M<6efj(e?Rm2p8-0ImY@4Xt3Z`!M9M^m1itzgJyMK11TemEUD z+YOPhLS`rE0t5ab`&08E$>xDN#vxC`Sl;43h3cee`i7Kf`q;EAc_iO;PH5njq6DxK zxR(mGkxfM+6m12-Dz>y1>b3}BEn6f)FI7UpC{@D4l#0pUl4?%N);7r`55tu-t4}LW zVL*$kZ$K!UV8C%}&Va+1!jL0Z%P^{7j`QqekCK|pwDSE-Dkj$4<}fzm8a6>CN1mQG z9;!~chPTo1*cDZH^gC5h{(8e!*KlT%E;>zPJ_~bn8gBsnFa?7zo2%+UGpubSxlY=@t;2SqlL)jb&o6o@HWKnk5-%-jbt* z#%&eEM*W$UgW8*rC+(ApKw2S_2(=Er1a+vuJ?hYVXu@OVuOy$@O)U|W+nd8fj~(ub zY8^guDa_wBjAHCsXT$%}P-W*Lmp@=Qvead0k>6w(u32r!-cw@8jDhDGTIHu07Hh^C z7Bhyu4P*RP&vA1R=+(E4RDzb8Nr8r%%!7&=L`gy2Crd_+RlGsnz(GO{m8>`>jdyP9 zgur}+Ehw<;J-h`zzkNp)kLrkp>ulu=9{8D4;Fi3`#oD}pB zrB)y_OT#rV3zthV1M)DlOa&_Q%rH%JGWi5^AP+PDClA91@-RXm4 zwYZVLv#gP_yfT~Yk7>sCUX^}wIhDWu6_+O1+rYx&Q?1PO4^!D*WGA*{&Y*Aydou#F z8y@vlD1cfiDPZZNO`Ts{f>xjb<6qls`P>Mh^qGo3`iM(LW?3xauxqNb_*0`4uL*C* zM)YZ&Oz@XHd@YiEHYQe!knK$zVtNgHUS^5e1V%GTVXRdlH*RggK4tu{vIf~yus=#% zK18A5*|cc^o2737TVY%QK2C{cB4#6|r6^dksV(VV(^Z%Zx43eIA)^f4Oerz@46cRX z3@)(1ct`u;2Gs#Y84&rzsL5_}m0QGzMqL!gs* z5Rf5mxW_Um{E7B&{Ai8p*DTC8MH)loO@lVV3dUZe_;1YljVd|4CYI{n>oXYbKUGH* zuMi^&mx!UQ^W*1T}B+8Rqd+U3<4;n>Qd^h^ua_7b8W9Gf)s5HP?rM7q@$7hIrwi|E?15eYsJrH?-0 zxca_qvL}9fUVXJaWVxm|q0V<>3N!A;;EdgkVZ6SJlI4&ZpFQH5@$8M0_v%-;OLq^i zNTrL*zkR7gPPwAXR(YwUNMFtG2_$^>3AK`75H&b8NGNjsWMZ82e*aFxUc>jA<6l61 z{Dxs7T|gv+EI2&T5d=-*#YAX1uVN^ zTjUqkD;(xdHB_@t2;W-eYHO*Cp9XD4^IMOE^Lz7Sr-S{!$>PZ$_u@0&rzY)>3c*k4 z)PXRD>5Ojr$*?wCgs>R);)0X0w7tEAcBICHcDL4{b}(IN)`eNeO9dYbjRhAA4SSpX z0t?f8oE}|^DSb7IcmhR>ct6Z1>GHFq>@ue}$~}L04tOxYbNmK)j$Z)J@e|-Vh%NrI zE*AjL@d@BLJ_0<)DUcby2Y8NSfaf>_c#eI5=hy{!j%|SF*aUEn^?z`ViY^#)bXRPM za~HTkxeE;9?4sl)>H=_%&i}$WFy%!90MF3}@ErK-0MBvuAD-hKz;mnuJjV*ab1eVM zbF}}C>psph zgIsGZsW9A2GqO2IGeR6aA}mDXr~kpE0$N~wkz(>p*<$j2{%f&Ktq`SPc{I&kcig*ZYow2z}5|38?NL8oT?aH^)t=A(-pU5qJCe@8nm zUXm}ZOp9+OcEL9@{Hrf5F6ATkj&wIN9NTmuHv9BOLPvXqva|g*lWTf1zI%GVfMtc@Mj^Hd0c^l?C()GzXSIm+Y)$BT4j35 zTVoj=T61o2wWib^wJ7wIV_HTSomxhMxmpN=mt1uOD_69gPCUP8Me{H_1n}VYIPnY+ z8}lewtMUvuN%F7?aq{f`ms?*p$qrJ6_&n8~HPQ}$-NMUoV0!VLk&4Xm7dMPE3ZqL(&yCW1McXqhG@klEy!5DC_VDfR-A*4^a@R8 zh)?QT{atU7#vgewQ_aEaXiJ&ssMVM-uhQQycM;eLV>kP2Gn3@(BS1g@*vlp-73x~ z?kA*Ck+*uYPAN+VTmaAP)__VeQ|2ROd1QG4>77YN290_dpu4fBIA4fB@) z0yh^yHf331seNTh? z{b8k09sFcf@0laG-!l^wodBp5@%=xjl-4{D{m!xB8qETz)Qk~Kb{asX-q1qSrvOxH z(w054=Uw@9-6j6hX?DS<=_e!bo8(=I(m^6t!ht+{%=<5VJE;! zbpWgsz^TP*xdE)yA5@Ba6+op{$itXd$U)`H|DsYR|DsZR#?j#m#$e4sV^+o{V>yom zCjgal`X5vZnT?36qWgdK}7s8sU5s8su}*{935Nn2S_e`-gIx~x#o$ZE#c$g03+8K@nyzqP|T zNe(TU6nw@z1=P+I5vAe_pmwAi=?i5VSySYMxGNPfLfm0WC`PO@3S6(+__uhDghQE$ zMDVa&&9Mc_&9NY-W_rHpW}tYQ|5x!O@q{>Jxss{VxB|7~Wb$wAYyq{i2h`3HP&*&~ zt(~s_)DBMijwgOPqYYs?5Q=u*OZk-056U> zv|T}#t6iZV)ea7EYX7HrDuLpu25P4ksGWMCb{c@%X##5J)!*8AByw;nRPZ4jNKqqd z@A~CE))V6wcW4g@(ea^{39R73`|LGt>;~FQ!Mw{j&EHYN)fiL+tMm^(k?Vc-M6Vkk zSEEZE*6=7Bf!GrTA=_P*hxAO8UGLROYrj;7R+?plpv|H~C}Y=HrPLKf)p3(RrjDca z(=y$61(tCsix!?QR$M^v)Mffn+4RW@aXnEyZ)0W;Tl$N)pq`4CWHNJB*5cIzRvvYE z7#v3`QT|Ai+po_?ubpGr=9l2L&UH+=+Gf_BF{gB7h6{QYt?-_$070@U!W5>o8Fqo? zy~x4JYEXegHT(u=HPc&pbCRRZb~+^3RV1u`%xU8NkqL*g9*I$5DV-pPqKMsGfKx2~ z!h8bKv4V+GPg}nH6salZd3-HC_B63emKIz>Cj36~Q9oe;Gl)ZpuOI>=z^M0XH zASYz=xPBm!!D_UBWPmmyLN7-)G2omigOB3*&PZXfvS>A!DeNs<%vo>hdX?nxVOUw8p?xb_(^uo-SjW8L{ch-sCtGQFg!yygY(thhy|`>v(DacBo^798M$EB5RdrD6V^@}d;n z71N^!ogBu^$7Kf zSP1b^^)I5{jIUXORBIxG*evI0-;eb58yUBL?ECzBEXb<%aC4RwSLQ-`!uhF$iSGSd z3N?JQ$K#(izF${74L8r=hY`(u*b%ikX%WXV-Ys_tX=$OG?EbfnE7-Lot3>q60 zd({vW3yTdBhGT<-!Sz8C;H;nt;IkTKA<$ZZeL90+%jH26Z8hV*%FDyxg5}{b(CRRh z@$E1oet8&Cy*!*T`F2=&T1C{NyVv(N*9F-J=4o>>8gG*z5n{TEwjnI@~SsH=? z4@oP52c?Jnr=_zF*SD&bSB7Q&dPK;TVFYY-7+$wBobd4NFm%)6HVfGP_Q8J?tj+*D zq`Q2{AH3l^@2!V6KUhP8-&;p6ey|>~|6skD|G_$v;Dfc=hpU_XJ<{RAqtfBJebPfd zv(iHrBhuk&z0%=^6Vl-rLxMLr-{XS(n8U2;BL@95YCM_ET-E7G-2jtmSD&z;>zEB- z8pfYGV>iJDj2`^x5UdWGR^AJp8IpjGl5IvuVdntD?<+bnl+2VO%&NWA2kl$(hY4o2 zH5kxzH3(z$F_1}kVi5V@nL(s}oPqK|ih;%dVS+KjvvYy!@WOBH177^*={7mn?f*ax z^zWCzy+?JRf~z_Zh`649JurvE5nt4E#Dul+{unj40tKB5?)1I43Nlgk!JAfnxR9zo zyZ-|Pw`Fi-&G1Y7fvPxPf(yl8hJjRHa=h!0RtI-dXDfsGL~(koxOczyVO(z(50y&I z#HqKX&=X%ZF%Zw>-^$izyDy4ggmobT{#7HNJS5$g&uN z)Yyzce171&MWv-KRyr)qFDruRt#r7q>nnmLEOq8)>nqltSn6<9)>kla1D~<=6}j&$ zbUqu`SKNyQUNM5ej#3snTtvX@dvl$+?YauZgQfYDQ)j0;b4&A`yUtED-AnV;E6z^K z$08yu7g;O)dm_sPKb3P8VkA|gdoS;nvI)YXX^OTT*As`EHBlrEAO>F9V>SLAjY>Y!AsD@1NC z&c{NXoz_D{L@K+pjK$2=Cspf8)1DaUP*he`=#4MThiy7JExU>gm^=8JGjs%fiMqlB zX$w)3&QTe>h*>~~E9skthtHT2BgabWWdInq@LCWV`>TPz0k@Gm7Lwfy<#bWPJ*iJp z(6M48E*d1F(~6@KZoMUh>|_>#m9ukw{$q;F+TzESP7qNVW*fm}bB&;Cc}5`h0wai0 zkx`O{*|Yd)*Nb=I(62hq5XD(%jKQYO;G<{HXI#c3UyKh`r&Yg$5f!a*M;EShL&`Vo zpj~rDY4aZ8L)L+8m-EveiaBRGMgy`{K%3wU?9&r)2V9uzGq2x=A1 z68Oddmxwdi{>WJe4)J**JDvJs%cA+kR>8uHUeK2p>SxV2Q8J%1bydD(VtnK-jfk|b zj6llYGhJkVX8NoB&h)=?7JB{S&6lgACz3(EzYVKsi6SH%dW30eaD?J&afC=paQL)} z$G4KgUvuk{WN0Bt9K?M{9Du3aun$RB&)O?uA7(mXbReowUj&&zWi$@2) zLE>PcOwtPak3vaKW1uh_PTC)&k;M>h4={$rFxY~QpGDlEXF}GwXQJP^CpN@MCixFA z90{4I$bw89#X^KBt0BUm49LWCG-TpDA83Dh;qNP=E?!m^Q+VDO1=Ef7;n zg&~Cbv9!XJ^>o~X#@$@$$)Wi14g|yq^bKRm!5hXfO}H_525wBGN@kp_(q- zlYM1|f)1fhY1TWZzC|UcO2sSR&dbnj)y@NS$=k%A#Mi`F&YvUu2l&*drTYtfy6ZVR zka@T|$k@0$C?h;E4q8$Z1%pfrTjc)%K9%Fg7~ugD8<KFh`nFv_IEg;s?)%fatUuXAWoop4Q_t*D|2w_!|GObFI=62t+M`gz}#P2ys#| z0iv({Bmx^G`H~J-*_-VvsrjDm5b-gO{Nfel|HLcnpV0x9bLt>Q@R34#+46|fxiw*T zcArmPO3o(+Oyxt}rerLvc!%y9wvEVewT<+BZ;cEdYfX8_B^DSN9ut)n8Z#Oji~?5& zp|&ytV%nnpVrKGvVrF<><6m%N?&V%$hAFsL`}mOxG_G?})po>`4K~C8HJ#0bFh!_F=%nlu#7F-K7k0x$9wtOOH#_i5IpkOu+l#7$fjH{mHN^q{D87o9DNnhYy-Yl~o{*f9jMIPsM zZZfBf-6rC`mBv+{Q0NR{Hp3GFprPqF0}xY*LGj0rW{F|C<`Bh3^YBnIi%j`P7XJ@j zZxt3-u!M^e0wj2F*We!9-CYKEg1cLQ1;HUeaCdii5AN>4-QDd@_CEW5=i%O$ndzxs zJzdqks;d8~s+AltYY-~NVHg@1WB5Vz%FxeO(TJ=4wnbX=TY{o7M}iV zKnio)L;(|4QWcYn+Xb4NqApqmk9U494f=~}27Q*tLoGD7a<(qye?l1u8R&g~bJPC} z5vLd4P#*gaGNM-w{a<9nWdL&>L4|BH+em56wIt*HmJvVe0rR@Zi$HN4HtjR7-rY`;d|934b>FrrVw&FlY1 zl6Qnen|I`oc^l5JjZ0IqszF*Q)>!o#CYs7D6kR_a7Xo^XiO4eE||7;>4=zN(qsin^Jb#KxJ>4prWm zLBNc+jGzx4eh}J6_^d_pkG|pgIR5J&qGx=_kVEru`7%5wzx3+5h( z*at-$6i{-Vy26J?r!nEvwpiwRBLNkW70VP*(zVb~Qq_U(pvv8UXN^J2dLZ<_cb2LJ z3HE}yN?X}vftPqDGz78>Cb6Uq`^WzUbV~Keb_aM3E%AT)rW{U=AQVatAsZ|=g+yaL zT*$WA+f7?VO*p4dQonE4_2rZ;-(uKG+QeC1(o9wTb3f}sTrpJzHRi0gN}2yY#B2Y% zdVS{ofWqpb4_ow>q)CuiQ$(R=_WIZiH2VfRdtLQ=67=B z+yMq(C@EK=kEJzS5fr0)yua8}Q9`e*#RF*TAcL_ipg)z&>>-qIv&k0MsLi<&|$0B z-;yE7$}U4zz0lmjHdJVkCl+@5%2Lwo59sI#cG>gpoC{hKgH!daqN_>+5_ALDZDL3n zV);)DA|6*&RJQoM0i-2xpLIaG_U?r2T;7}#TjX2#Fv_9OK@8~dm}<0`vUNIiih_L_ zsQgDn%!VU`8hdPJz>FgoMW>4WKn+%pq%x z4R5{+eH|Y738Nkb6NnWR^kFX2O9H+7*Eid8H=rAiUzG*q&OgSwj&BX-f2pKx(h$$K8^g*a@A!NI8 zkHp|kO}blG?yS+kiNZr1i}+^`i}VN;iNJ3WBhe!iA}0F2XmBD>!e9zUE5bk|DzLzG zepDnagq6Y9Lroz5P0ISYg_sq;jF6SL4xbe}3%BmD-Ss=Hxlk;Plu)cZm5_`OoDe+3 zpl1jbNU&P*Db`=TqAtk(6$FT^%kU5YEUxA2@ zOrHi0dkhOQgQJrALOzoG1ZRha6uU>K3~a|8l0X|vdtclVM-@H>A#=qrq2_R& zuM{3(zX5!Fxcl(PpJO;tzjCE_;CJ*bQ1Peir4lNZ#taCvzCJR&{-U_p8Q3m6B(u2~(qsh)7%AMeCuS=9` z&!z6qQ~TiPVug23Z%)}ef#4|YFwQR|58Ai++yi!Dm)%TD=LJzXk-X@nToJ;R-bWLe zkdeUaC};H}6tr5T#6bt>y=eJJ#=Uwv*KqzFgK&e_f=twr+pBns7L({#tsD^xd~C2V z+4`OS$Nq~c&Z)*%by6SfK=RBMm0yJXX{KB*loVdrL3uG9afoGPAUz6jIWMbMztjAtaVZ zjsPHvWa*bckHkShL6k#t;Z4kw*pA!$5Eu(y81HLPpf|4M`Uq(g7?=RSufGgN*er{sx{R9-C}K2s(I86F0!APA)WAqz%B^X_uJQ~@fYY#zWH zG0oyB$piXIF<_^j`@H8q7QB^81dxf)zacmfiz+VYFEc)iJfMyt55R7JjXjYghK&SE zt@sh@7Bv<_UPvD8s>kq8XRic81i>$qJ^)W3rNGh>DO;#=xPjaC`AEfG2`tct`^^s` zM*YI9na9`WEIllv+Ya+Lzln#xljOW!s@!^VOJv>Hr?K$o#OBM>173=6Q$Jw7B8W+L z1l>btyz%k1+}(E)c8(B1jIcgG%<=lv-Q4v=ot+D$O}|I`=zsSN^6+{k_)ge4quozd zVz(JQFwo z)A;rQ=cR#PO(B>K(FR;;?X%Mq)%(f#Tm>I!Lf@6~*)>OV0nn|5Ia@xVvo-%h1nir% z^y+dl7Uq9A?!3RfY+iF&*Gt#ibd<(D8F_PYs|c>BokJY7+F&SXhkY2iJbv@yX1}fO z>43w6`6*}Idg_#tbSyoB70+BJ-gKrIM=p@Pgl6J=fe3k&tblutbSwQ!q1ni3)yKIj$% zbmC={`qGUCZ6dr+p1gm5N=I@3k+%Ksi?m}`U=bNuKfyp?fyb+??CaCPmeyWiY~}V* z`;a^aWptAIMvRsxRdsPj^jzCwR=`zt@W%FLyI9UMR9bBKa60Dcn zO&QWkp7A$qvjp4Nr>}jD?G|^dZ)h!_7{1ZVN{Tdh1gKL4Zt4}fiu&!`YJJ~I*XYEu zV8=nYCK}Kpdx-ij*Y{N3ZC#VfbY8l5tC(rg=kszYyJje+dcjdJ|Ah zh;K3Bo^X##<6%;CjU(3z2|~PHHvx{gJB1ET5T|AiPDl@w4lMX*^B&^WPZb`7@-GOs zgzaaP_E_Ds=}%&J%c(b-ZO$yb{(|TJW>llzGrtUW>1XJY9+HRY+*TDprqzoCQ*;hv zW0TKKxEl%VL@4-hr{3&LBqN6U)pfVN&543a{#k0uQPJLx?}8(UD&$ ze-e{Paefkl-ozJA^mihaM$j|ZBt852J^sh@dlcIpv;j<6+QaEZx%s<;{#QJ3n(Oc2 zN<{o0LHY{8C8hd5KR#&ixfKFVBPf59kR`a&RYPW;;_ayji`))nJ4IR!h&pBP+PQYl z=bcdmS{hIaJF-___ogKV&ZfQU^kx{Y50)8g^Az0#@rJhV558(9{Ny?K^c=OmPx;(; zUU#DQYW*~IA3Wnv-gc`JEs;nRo)p=kDj?u~^ZG%UXBGXFp_5fjvU319H+&_X;w!#6 zFpZyH@^X9cIG?)gXMB~tID34aI)~tQU)QEgmpCj!(-2$!pwv?BwBFObklfsb}pIQ1x$RluDo1$ zUif=f?q}Z5$1yV+IMo5SipbMrpROO}%MA>G0@M3(x;{o*(%xyM{6OVx^YiI*=9}l! zoZW7U}TaK5jDO>4mQu>yvX!M&sD?reiKeWqYTZ(SBfaUGL^Z_lkN2m35WD?+hdwK15y?IE# z&)u(zfbmE@Tm~$=!r#629JSXX~2t&J}>-dCeo%`@Nlg>AoZNszGW2~ zV`u8Ruou^4k3aI>O>+@;MvNb}xlM8v_v|(Mz7X7vLEC52J4G^{CpalP=B7Cn|JcC? z!dD3QK|Va&X$q_8A`4@c1)YTND=!?Uz-p?1)7V)ot?4`Apxyh$h{E~%y}r-V>tkW( z+YxZ)a|`&~KI^ZQ>TBJ9pJ6Nj7dgA$U%hVJ7ipLB1D(v$$v<$+nd(>}FG~372&y+T4=w5*g}a(7Egc+* z#L21+%A9e8Oo$o^jo>AsM7=dg6Kq0r*t+0>qa?jW;FWb=@~W`aglF;0egtgH5}is@ zS0Kw5)EXg5ZM@*i*1zNFY`89?C&E9-YwtMX_~7jce`8qLhit4$W>ECBE{Fg9BHr3{ z(0a-+S(17&L(J}~pvv=CGje*Tq|*BZ<&W!OW9FI9zWa;cI=5bF;-tBg$7kU04LTuz z*@Rn)6d|C&5lZ59E_ZO9y9jiw5NQq0^Vt?2Q#5tf7k+>7_S+oRy=3G0aW^~!aFNCi zn5`$Zy+D^ct=dqj8Xn7r@9<>H450K~l0Z zgj3M8-#G0$sS&}%;}ehA-=vKRRbcVm2k`RX1~G1#)-feUZo6jd%a`k1z-Q@Uy+IaT zKvzK=*{{+wdFlc^=g4mRuTG74B|hBkC&y|J3{|2nU#bRQUDogBy4$oRxna@Y9rr&g z^140sv%em_Jn#|w0I|=DL<21Ij()Uz?k@`O^`5JpX&Ec;Ps#$fnXapc&gSbGD`#>m z?JxHtx2$d7CxIW|-!8{0gQElxIWT9o0nHHhiT8z46y)tlrAGDKX*3_U*Y_t`#^^(b zm%rNqH%)*g;m7Iihq%Mc%1=M9FJz*DsW$KO$V7O(x98LwU}f8Gty67aH_LHwtZX-) zG1JZa5^GN;(-WV+zR7l1#g<~b)}wObqF`A6{#L-&sDSd7+Us{A-8W0$p{?@q`;!*U@^%ivVeO)c{2rs*q@{O6#^SU!wqH&Li{~G(<{IdLUgffym zNMLGZEnUC|Fg*-p%&^BYc$Ljy6#nMaid#cZa#lIB;C8GJ_x$(UUQeqk?>@?6RCxUL+p*Aa=Ql4U z^~d0XfqN|vG@@7d8_MwaTk*ZCJKZjqUF&T#fUw6bp+k9?@>i6R636E_i_U@J zzMj=nEP9%>tqF%ARRy2hLugm(0@sM+->n6!wD%+R zlJred065HV(S%|3AHZ#VoslEHK0luc9#Qf3PSp3Mt&LZBykJN)*b~ja>thRf+d9>s z5$LGyjQsH`vomk~PJ>b7g_6^W=yhvk5@L(5rc|-JZLLpe#?`;jW3i6d7|??y%_+jy z5EVS*0W^@0b<&rtaJ=vrWOowp%E7WZFC*-}*nsk=Rofdggcgttqf zUW&uAZp$WtR8%HmFb7;G-{YTaK){w`Q^hVwVKqE$bSXXUP^vTY4fxUj^7>wldpCNx zx_U-8Q!n)Ra8bbB(H5H7DfguVoa&gk^2cUZF5$Unmob9#9$bjn4YR=A6yas{@NgWp z?)CUMoABMY_i<(WEor&cwosSoZtZO(b$t&Q!Z-cevZ!;_xrB(cH1~F^HQBT4+G0A< z-ajB;n5g=ewP6H1l4p2_n!%p*jg)7%a!h4Pic$JuIpi$#W3BLQ&wik$|l zpOoroeV6}cXZODDX7_G0tK7-Yhy1L|YTwz#Fs9#9Jfv~iiZI!)T z0ci2+@F8|S)*p2o?QbUA^}kmnpBuiIua<2#AMbbEMbU;g-61RAtvsxlTFGQ&c%Q;L za7P?AbMr3*$4hPwsfQK-Sb!f=VT0ZX3;#X$_{9Y7n9Qo`vq)Sjup2%tptzb z#(P=#?rG$IbE;cdGj>&1w5YD@o@5EktKOSFAY)%Kc|lOh-$@N1yWCD?H}4fk%igc8LxaLRR9)3XXMxhTYSxy?ttG7BwFP6d6(TGYJp^1Md5E1-TG|Pb~VTmX4w}|$Y ztx;9q@sP2hU5cnY{h5SME7Pcd!=o_+0^ReNXrao>JGlG=Tx!>Dbl@0`aP&J_Iraeg zx(^)a=@fAN?)l@f_76`fD^k;ITH}lYa{Cvo*57A}{omXKRTg5fjxWNWKkr|>@ci0; zI~cgH=WoOkU~lfh9{9V7pwQZ<#eP&6Jklxb0Q|hs{&*g~PJ&Gciw>3oS-}#>HedtW zMz?$4PGjK$7~pBK1gzaEUt{ltFujgI z&1&gu$!3fCz3$Yme(i`*UA{t2xhFdL$Q{qGhGmO77p};d(hWyttHWHa(u}#mnw41h zFbkr7>J7(WCA>tM%tfuU!Fg#j_7<(n*?HxG229?@`pnXWmghSy7Kw)Yo(*uV+4A+g zsKK328;<}l`GrmcQu?%P_ay$^1e=xcI z@}uL@wiW{hXYnrcr3kKmjx+0sOHN^p4xI<_Hmzx!0fTcs+UTtz|8K@{KHa@(Uw;z@ zWC4{ca^^M0#K!5z-D#$E%DBEXTsd7@b3z!TL6f5kSOG#Wy4j$e1F7G|fa zuBIz|3QqUpN7HI1Xj46%$+W;(kJ6<6EBjF`UBXu7N`}vtY?y>b?n6ATgpHc%akYQ^ zbry6Z-njvz%d^*7XV`OMI&>MpiTJl@?N!s;y9YrdeI_fylJ~sRGp%;SqssGiGNR-x zPMN2w!?rXBx3~m`zI3Ue!uu^;r8V(}vhYDVao^ukKh5ZQE(FMu=joRR(W;8daFxNcKn72sv&4r8giKn!}^f|u2Ar6xngup3>X84 zTk+c*P8m#UG3?aJ^r%($g4jATf>lrNrd_Nl{Ak9u8))bI_C_gwhOaH})4i9I*X>xq z)h%AeuEcTqEUYx^Ok)8mLM9Uub}DbpZ|)T<6T)*2Fhz?@=DD~(`Xu!p<(~2CZ}D&j z!8Q7y?(ulwL4`O?O6|vMCs*Rd>gy2K;_>%u=rh$_72H4x#v?X`FI-x`wMy38SFa<9 z`@c~qsYm(z6<*iL`6mu9U}X~~!P_Hpi4$nf9*af9E~=$`atNf(?Mx@5>yy=RP$OWq z#s;wc=84;aWa5*q_RN+U%62wMO;ty>b-#xG-N^5ZxD%P*1R*=2T&8!Rr7WGulc;#Tb^-hG+mO&lPvox%NVQqAv;w{>tl5;H6z5@Ok8PUYf8X$ z{&;}~`|=9939a$Xn1(=={7vV~jS0>fCjRKedFS)@@ti-xh#l}kHpp}I3( zlpkp5nVT>#eh_)3N!Vy5)-1~2#=Ik6tie4)iy?#6k`Kg9$43@}*cVyirT1D2dL4gI z@=4suFKs;&W$*8x;X8S)+?`OkD(4Gt>Xm>PR^-Uh%UwZzC7~H58tm(;`Lm~!n(>zV zo~6pK%5L!kxSa75>KztSgcz~AwmPMY8K@(D+A2nU&e~xbb+IN}o|V>@0)JSf2s8?u zi$0B@j{(kxu)8hJMtwC)dSx0NixK2>{?pMIrJsJ(7)|M@Cn#H0;()R^Xy+E~%w^}0 z$~7pbaxso~TkGOl9_7nH%(JEOB_=KP0m6Zi98#kkk5{~ zN#uKGpA~^+%<&&LiDtTp1vXM0Tp(2!#nKH#mwFHxW^%o%B)lZ-2BN_^j+EY2 zURBa6ZjX}RZppRYe7)nA<4Z;vsG*-Q)&loH1+$tTv#R9PZR7?j!#)Ske+GQ@n5P@4 zB=sm#x}J7b3F-DZPF}s;up4R4G2d3JaGoDkCJ;};s2&_;rdAb&lLH$l4 zi*S}m{uv4uHz?|?NP~Ha07GV>CHH~+OG~cNt_FC9Nk@^WMR_091-2ArY&2KuyeKEl0^fE)PuyyN=r|#_#eY_10XYOHsF3)Iakk@Y>65 zj@DMKkTt5W|Kyc%5UC}+SY{308*_5b67<5>n$5EWCbSZ*xtJvEW&c}kb-{+x|E;ym zXYKfM@HUF+J}dIL3CeF^XvLiY2+UMMfhzD$BeftF%S`|A2k#;=_LHMj1uW$` z)K#VMFR7~kzw3KMF&m|UQqN;)p%ijf^ut`hz@n`JWpjG*Buo*^!P0*?Fg1Y(?@Qw{ z9!tV@lmD}-6~5N0K&L13*GLoXjG;QP0LhjKTyQ#7|F@?9nNIsZ4qYU4KPqzj@+>HpSo zmd?GF`^S)T#d##NpY|LD;40CFdwEs_?K@^!(3-2XV}yxJW9(byI~dDR+?P#6(?JH}0b$d* zh)mUow<}iLw_(tz$+-y+kzc1Sv{{-Xr(!YKnrNIFA%p1f?fif+)foasuOXv%l@c5~ zKw4~ORY7@9`aHHA*V?;A)hS&;dd_G)wiwUu2Xp+4u7dEX@`MTlzKzGQYAk_*^N?_- z3LTb}TUfsGs=RbExVXP~9e482l?XSc@(Jn%ga)qNux19z4!xEE>bbBw&V24rB+3r) z>P~9auttu2&qLshqT@)Oy8h$waRW_Bbcy9;O^VIY)saP5JRH4TwQGCskO^C_PeDF( z_eyfYe88FMl?G;^m47E0dkbnWe}M+`T0go>L2J@O%p+j|h++0moU{pdQXcaUtXHvm z#-*I+^4moBtv^xPE9v!l9r+;Q#fG@yotA_Hqxy_|4SL{j4f==)Pr`%eu1`LQWu_wT z2(u;rW?6UGlyZrQ>>#^viL0U0J)v^+(`rj+DhvrTtiyM5tek{Hv?R(l# z%hRA-3GD?IM(#-RmHpWBK;&zIqF9pm#C?#_n0Xq+Q+}dYMem<8pQiY3zdnQib$@X# zvc(cJL_s zd8h(veRBt#8!Fyhhq_qNT!&4lO;t^3`Tmaz3k-wFu)9?VmI|P1B+>7n>MveyaTC&# z-pbeUf~om?v_h`3&1C`0JZ#$VIewN6xL#QC1D@uupk1RbIn`b1s&rLwcrKrsD{PlI ztv3IH&91WNaf1x=n0l?4Ik3n;ePust(! z2X|x-e(If*;LyR5EGj}^YqaP#149hRMKl*XG{#ElfG`qB(f!ayJ;v~1HF>WJ#xqK* z8VQuERgEd#n6mBpKp$8KCt&a)tz=*3oy5gzOt8VZ32RVoq5<-e&Novk7k7OR{&HI< zW%?6`HcTFlZ3Bd;M4DcUgk730WR1``L*P7lA!FzyqnSFSRZ1$pvjJw|rreh|Iq6z* z5142b^*b}gr2*q@hVDnhsf3dd$aiRva$Hf!xU9mOQU^vam|5C_boQf8f??bKWcFftbysL{uu<#-E@#`@cg2U zx<;<*d{;i3_T1h)0Y<56ORlZ(YY2u?Yi&tO}W@Xr>J zSgSQm62wdQx8&|kX(uc{AFx&cJV$VYYPY47EL$24yUDU(122}ds+4%CjX?+IFzo-R z;Q4R1}(^J9vZdC|JtzHMA`kPGk^-MN!8|`uYhv?Uo+RjLlYnFED>L= zjWOgV(MJk)YnWY2|BtP%aM^Hva(tk8(H&qC@_H}2QS5T35+GL^+rRRM8Zftl=LdRP zbhrzrOU3Tw`!0>{Xtz?q3F^5>>&Sh3=q44^2H21 zOQzvI>#Ax!I-03gWFD3e!-MluhG?@~G%#o(?!hlzuA0TP#BN$kYzCg?Cp4c|)wZ}p z2-HncE;49qA)OcEK^?Om@zN4MDwUUv@8h)`kL#Y5_%s?G?t)KzEGZL;iO%|%=W16q zv`&R3)GF|fhlbfybTzerc1JU{ij>2#;d=O0&1E=eqa^}8t415Y2rWaAxJ7HtT>SyH z60M^p>En&5`rQU*$Nl-OEv9zu@Z+z}b{_Q6>ug_jX;Sq_94XalG7op9ci~rcv>v4; z)ENj)4u?&gbafqv+7r*d{%8$@J^+55%_w-zezQAf$yhv$4-fnS{{12A#zaul@?|^? zrDuooq1Qs9TC2#udPU~(>#!BE3-DOxzkvFA&Q7OEX3lyjb%C~FG%x1TH5tUVO7j)# z%%rSot;*~DUGT9rCrlu_wLV!4Ke-7|cXiavAX*Vl26YgxVsi8#JK;H|AB zTKHjVI@vODbF0WRd1Ca1&)k*#fq}Kt>6gt$Ym4UdcSh{LHV@sUYZq$uAG)$!ze(rIVs*Ww!`Bax!t^-|@I%bIY z5D7Ho_!JeE7o{IsIu&W3TGN(Ldai`AZM3f7tL4OwoF}EUp2FMQNaK~vnjUMda<5t6 zN>8NfA_rG+tYawitXI&ZPCdKYq(7W-EaYFc1@+39UDJx62GouS-uziI*=XIwPY^l? zp-q4|4y7F~Y}xXXK7Vy4TfpPc4|y9nlmwz;zj|1|pqPo5t5i_op2pKkQ?~BjK!4%c zJAvEab8>|}sNf1_o8;LKbIJ1D535&f*~ee#v7^pYefR*s0pintLN3;}qOZyCu@P(V zY{(xp`|u)*JEsjEpJ;zN4ykpCnV8SD7Mi%_rA64z8jA=a4N z&QeZx2Cp{jOnf2M>8$0S#w4b4@_%u1Ie6DTY`>8BJU0J7up!Lgj+TcQMS2&*s#!US z1%|uHKH$&gU9$$;Di>wqsGZSuNw&AOUQ<)NA=pQB0Q-pa3}7Fz_mVu^+rHSe4VnQ% z&aG2Qm6p%0!Ln*~Ol{1ig<3WI)uzCVvmP&!sk4zjq2_3)aVjVyS9$wpDUEdWJgrNa6`kil^bBzWI~95WD`P6tHb}8&{iPomgV~(z1UOf3S1KQ?O_IER5Ga9Yj;V)S}kO&#lrv zD`__0lN&qk61bz+LL1)8I-{#enVmZBRLomRayh;95*GdAXq1^r&czfbpn}^QC$59L z70TdyI(_DGnG<#U{YPv|&XtZ;`7NU z+?NPfQ`iT29&bc^&(jlb`!QEn`aD~n&f5!ZI13D)E=W$*iNrT>!g6Y)?4f&Sba93) zo1-R#Kx{wT`WWWcKr?IcdxcKWyY?y`U2}x-Qp5EdT(X1Xk4evkn-1bqW*Ob`GUXC< zg@q^iKSiGldI3}+aWp~G(#|&=SWbI<2&t2HWTaAxWU`NEKJyeio0}b^pJClSAb$B# z=C*RWQ$VWyVNnXf%)k%b+Ds-BM45oxoqxS z)T>$Z3kXnmtR>SoAsReZm`c}0y)Ck$V$=k)1T{eN;EKxBCXY)F5u1hu5k`+t`6gjJ zuBnO@pW9c(Ef!ZzS~`V>2L~v*83+AUqYx#CLJ@w45H!j)rET+%&S47tTMyhpxRz>i#S-0Fl_ul4N>xGn!R8gXYwLG$Dh> zLqNNA;+z&x-@_8NCod7!%0s|tbAB-!|5MA)OBEeNqJ%-EhSIZZazm!veJFL(0?cj4 z1exE-LjP>#Q%Rn5jgp{~zlQ;2pjKgX4r6~iEKrinG$2Qf;t3Ei?7TP^{kr{XIM1-6 zANTw{`}p9L(V;Jpv2kl&D+YG83J_-s@pg#evZ#A%aGO zPlqQAi*ydyW%AO7FwD}+Vt+*A!vRt0BTUq?5nH5fB+Y|^SNv{b=0RT(V*`iqkbY;T zP*jF}RC4PfikwT2Tq-3Id8MBwWuzI^YOZ8vtzrb)1a%*aal}KBU4NlcTH#!_m08SY zLslqBgszCQ65HUD3-)qJ`v$m(ems(Rn4RKtGJZdH@LsFXJYV()rbV7q7Jvz&6dygg zj*^9jl$S7xJ}ghYFn_C~t9kpev;GqU;fQtX;ZR(cuS-f5IHCQsoWy_AaSKJXLE)l3 z3L}X#eiTO|ADZP>t;KWv*pNQERreoGswLR5<`lCP$4`kQcQ-?Z-KsUo|QYrC7V&u%|rtbOq|t8$n)Y_bCJP zt^+(Wtk3;Z8+hLhOh2B ztn`O?(>_Bwf1%vkuohiVWEF8pgFB&#{BBq-wyt9w>p+UvZ;>`AQH7T{G{{BBm)sh( zl^lXSkY4-Sxz+){$Pr+d511YQE8?)$XPh>2X#a+C_YL~16EkktSQ-L!BdhMVJrl=3 zwLQ{4C*jbZb3`Zy@4%s8#Xcu`|I^J_&K=i>q|*R-W5soc0eu$n0j{pI15V_5(%Z2> zHW^CN5BM{otoAFjY@e3}2|oEX6>SrLrk!K^tUxXe%EpF18ZiYrA8q7lO6?{h^ly=e zvejQzTHscK^}g8iW#ZY}Km_}LUG6}O!+vtD3HfY0^=zH(uylRu{vfI2vxWObq;`H~ zh?KNROrSQfKYz4wdsD<-Y@hjZD`$5l6f!3SBWn7K|J4ro^Un}5jvBN6z`@2?v0i(b zj_;o$q$BMHdL)1iIHd34VWHu6*M|OIWP+E%ext0*qkj=8YYHM@q{8kXKqUMl{p=r# z77ep*>K}9wDsPa}E7sMB1|9H49nv(gTJ@V?pfJc+QVc3KF={~>4s~sX7FvvwgxeL( zaKmVI<=6yTV#`TkvQc=DfVjn;o`IpOodB8W=g6}SEJh5lytdaPPBKrpq8e9p_a828 z$e|f?bLJIev=cT2vrkU#4?Zi7VOdETN}ZgVUwlzp`XJNx>){sMSJ4*PIEMW*sKEG3 z&jXo7o|q^>bYo9;t{|VQ0e1A!DF{|*vW#+W8`5!h#cT1i=%@Q)vE6{e#u*dQtZRN1 z83ZX=z^+zEq^0#){-v0CN2Xl&+X;<&LM z6lOa-O1N7B^M>Ckfk%kR#GgF|^Sbav^-w;e0b8PQizl2Y0X?8lv+O4^iqFE#%+wbJ z(fEEx_)7?%F9(CVRwM|iB?+gAp+Vxfd4jl7NYq8P${8O?sCK0;5@Ip}_h?Oox~7#A zAgvgRQK*n&yFZCh_>V8iA}!`G{2CmT^MKe*Hx-?78DV z4N=2l-m;+`NWwoSI8A`rgClH7OUL84{DzFe_XS<4@Vt=A^B_dE^|40_4&&ZT`=V@7L1i1 zK9+|(UsIz=I#xEMZV47@1LYLI!co@bW;Hjj{cy{KdZe{YjCQu3@DZz^RQ5$3Kj4tnpE{Ud^uElkq4RgeKupT8OpcK-IUC$KoZx6+xZ)i|&HoJ8Pll5rhx z-0ltvWc>mu%7A3(P_;O%EsSGr^L2Gq-Frf;QOcc&9rhWu_9A1Bm1dRyx#oT@c}*YYFQ@OY6m+SJFb37dgfLK5{fsca>FBAclVbd;=&b-&bQml` zFc(0?P2Ftqur_ucy<5(97mcEm>BL%Eus9rbsLVEImxFEbbDP5AYQe*c8mOkHHLqeg z8kjASYj3FPIuDMtw&moSY6QgQ8ZJp`x?(++YN|Pb5hVd5%OKuLYbBS_UqW*Z@ON?J zXFtbKgS(IN&`pVR^8(0ZK~R8HUfvr?cgx8h6HHuSXDu#{L#EOxtzaw70t$!QecEvnF!*H>h`8Cf9L18g41_T^FMf>h!woe zVREWxKl$>=@bTHuTO8yx8!tMz4Ry`j#mH7-%X0A@Fzw!?_2o^6Q>gSuwaRKj){T*w z6646RL(E##+~m!XWy1reDp3*5a(v7t9K}uf6S5MV@;L4u!O8M0>2y2?+?tN#uG38x z+e1uW$746i%P1pMSu+v7o$=$?F8fR$&>}Yfg3juVR%fcG&kPLwxtHH4Us5ONpoDV)0S6W~uac!Wd1@c#~?7 zepRU#v;Cj_A(3pp5UIZgYElY^4oYnKloa*oILj7^p$?Uf4?j*=U}4mPkT^APSZxiZ znvf{eqQ;sv_&SV%?^53`#MKm#xitA$znfT;)i?NauZ%JOa@mM1HZ{LZtID0bu1QGf zA4}1K!LhGLptrS>%BriL^CulwLzdRiMlA}S7A!%C`(w}fuA}Qy5vA`QIN}_`TX8~O zoj3Pj(mY(u{|ZmJeE5iFbJlgZ>AQPQMfuaj+nhZ~fuRHoNC*}lH1r^CBiX|XW~!E_ z{5e)Lll>su3}Pq|0MjIm!8EBo^x&g7#4F<78X@8~-Mz$+o#Y5KA(L7M(maQ~gpi|* z2xbzfIwhL6z`gkJy<9{Qzx+Bw(z4_|wBW6xT_xWfEy9mxrOjfB+~Wnm+SuW8+m5Yi zTC96`6@hGpiGK-ae&+rAhZjznY4qz9ok*rR)H;&_ zR4fv3O-yw?8QST(_?W>+iqv%6dg2_eXEYu;0zRqMWgo;rpVA;12?q2DK?c+xe4Ka= z=i(*%ws-Ms=-}gd!5Y;tV(zk+_In4z!g@pA!b644+c1ANyv7n%faR5sm$bhYm6Wjh zr%TSHkkua|Tp{NS=%{^+xWNRxXSf}yG$i1^;xpI8cP63k&xA>oUUGyMySL9aT8mNt zREeon?e`OOyTyu$#?Xozh$FT5o>PQ>Cc_#N7y(0T|3(^M#PNY4ba`Hri~kZxpX5cr zym!%#heQyf)iP=sPi<^F8dV1r41s_xjrVE{N= zHAXSqi4V}u{-uhqksXb}q=nMAXENwg_Y?2_%u?xIQj~R*LZq9Z$*obkRfJXVKE&QC zU=<~2Y2I*Ke&s(?_3$s32>M&^)|35J$tv@dby(?#TlQ}%9~TpGx)IU^;~0;5k)PvB zt(O-{T`7k1C_T1It)Y;Al1yUDfPGW^8aFIB*!_EBLsy)b*UDMbx@*^y1D_jiuKVxNZ!WXr)qLd~(hbD&NPNfIHAEPs?Xvvz z@g<~r9u@=iR8t+7UsYDO|6zT;?8xCm;gK%CH9DD%qRa0Po?8YYb~s>KhmwcyV`kcXudm#W(KmR@~j)-QA%ScS_Ns z?Hf+d{GT~9^M2{dg1xq6(Clw4MF zWEP2?*pfoEA19n66-;}_xhI_SlucI@OUGgp)RG1!Jym&`$<%H;A~nft%WPHUWkyta z+3nONZ<2y_dNWnYbcpA$IP}nl4-Yh52Er{CO}7lR+za#C)Dn8%)GeB@b=d4<#(>s4 z^EOEQJ_n!ZxEuvKFXmn^B?Z#Esq?Z?=-rMax)<&&$*ntOdL{KP|6IvRP`97BqH{ej z;?&@!qBgv3DF`YQh#*uGkBZPBV6!oj+-QqftXF1Io338bpvU3ZzTV57AsisHWh|$t za&D=qpF^u}3r9F_7#A7U#ChhuO9Nr@kLQv4CkIg=(Lpcw&z{ssN|yI8)6$W{^v<6g zeN-$DD3YNIYg}?wI2_mFH6~~=rhe2Sprp5U>1e1WcbK12i;0xb=A|>V`H<7myyz#i zqXs*cs*Uik&GHZLCp;Qk?{B~EsCjc>bPFl>j=Vi9BUjbyKTLKxZZkddc9biB&vax} z?3wE*Gj{POzbV_EQB3XIGnTAhe$zX+z&Of(h|kYJ)*_;i8N7$|ZU zHKwtsc;F=$&I$;VZuejsYiX7r(R7DUT3OOV-a84AEv5n;lo+;7D#nMR-c<0nhh@iK zS{}xvxo75R^L8DL`fihZdm@jnCy0TfO)IFe*+U+Hzoo<&OF{V2A_(i7922~ zON|j%2yI>v_F95xMyg&gnSe45_7 zr?HlbL~QMA0k<=f$*3u5Rt6MsSn>xVh~Z3Te+oEAlQh?oeRmc8g8@-E=786l(flA1 zPLlZrDBa*UC*YAV%pbv1V3lJk!t$*^2caI#zZ|KKr}rNp7TR7^s_s5=KaTMn(u{gs zmLOOXL51qz_w5)g6*LDrep(xf*A=dh2$qEyCdd$x)n;R2;{0PQYUGO=2P3&$v_&c38;?J6eb?og*0UvjY;R%`V&-C_ZjJ zAYV>SURH~frOx1hOlM+JvLx|KzCkh}^SkY%cUw$uF!M5BvT&STJdCE6w%sj_i;YDy zzeFe0xVnkWZX8QEd@kNCJSWI%Q&OObtq%96CM$y&q&8~lh|Ch9=HLy}ZT8Tado!6; zDq!DiPK~kl{W5g$cyr4xEQec=1>}v+^!<^{WbJM{&V9GIKPWRBC8^ejY+}vyDZ&v% z>rBx3LSEJKV_$7UOPa}#OJD~2gpm_3GA%z0rz0CUm4(DXdXkDm|+@Ub<~76LDD*<5YK(Pzzr=_xTygIulRhar12<-b1Y2AvBtz_nye zBe$^m_V=?}ZNkg3b2TqolY*kPU7~O;gjlUY-RC9xu_#J2-({3LTG)*Fx2O)6_yK3p z2B)$|O6V*ySh>S@mOvkzlVoW)MtB&h(4B-y)`wE4b>>B<&4hDVZBiSxvKCVb_Dd;} zm_?DGs9%QRswhxeF>+>viqR67(TI_s7>v)XO5KE_GnAo`Yt506XoB2BO7;UW^OEB} zhDz`)zPI`S?_FZLe@-0Vg3d@2Ss4yajhP1_LQRsok(nE;q!^5A3u`PPFLWC;Wca3S zh68mIJD&8imGVfNcn?K^Hy0*lCJLVpTfBGu>f7Y5oFi~;Ru<{ zn-ZB(qTox*K9K;p40L4ja)}=~gxrjYzvdx_zxPsomk)_3;U}On{AC|XxG5hXWyOzN zXZB)$N*T_A1BNX~0d{I# z5VzF?PSbG#t!}S?oGh-qDAtfthgf)eT?nDu4C(eq4f8@m{nDG5%2Z)^9On>pdUI6C zlEU$dAr29kHl*xDk%W>%G2OhZ^oB4fvrVcKH{#+FW1vI!Q)Z3e((0o-Np)|RAgU(Y zKrpS?=|PC9@SP2(Vq@Q>nxzI!Deio(iS|NQoXjs(fct4d{dSYjF>L6R5Y0BKhFgd= z4xMeAgxq>l47~=Lv{ZN~vj8QfE}ms!&73>RDS_6Fp!-Wv)kLVN=3crCa}t-tg6fHa zq;?oAc2uEAB)2qtT2nHV*;k#DmJgpxjn&V{VSU~^r*pko@keDzTh2VcT#FWAvqO)lL{)rKgWS$ z1XN2;)u&}z*ZvFoASKjFQqwG&qzag7%cLle>k3R8vfxNII8&z|C1>kmr7A^`qeb!c zZ@y6DK~<@)Vp`OX(LwkqWlDjkzc2Q;Po=)36i22+8Jh zh7z}V1D;cg4BB!~mK}2au}I5TT(SC&?2~MCz~^OagxD^#ZJYpE^QuLHZ>!YWLt3yG zKdj_3_JbPP#wXKlxcE<-O^=^Cg3x}@r$^QgDUy8F5;E@MNo~{I<@ndjA>% zrIX%h0nVB$u`G`?Q}e1zew#R|r8Y&D&*>6UQCJ97m#kSkY;h&kSE(>WjZ!f)g7B^~ z)X3?kA6H8j<{?0(oGRlcF_ah(*VDwCyFhc2eh`<-J7%)iBz%T^81( zKds^vSIY;SU^x$ksKo710^x&0a1w9$6Ko6eqT7y6Ts|IgV18VSQ zCeVi;LrFjnt_$?ww_`vLt`79zC`&*O-VgNP=^8)}&Zm|InQH>{;A+W04{iqZ;2vr~ z4{ibU;91GNu&Q)G53cp62e;7vy9fUU^x#-kKo7nH^x!Gub;4XJ`(}~!X_~ifw4AxF zKn?!=PYn+GM-TpUJeKA$1?a)Su4Tk;dw?Fi#Nf3DXZ*JwoPR<@fXWEy!O;^)-{^dd zh&eU_dhnsYdvF50|LDQx&HNM#CyWx*(hwNhOoIuR$AKC=6{x|@ff`(e83gp;8UNXX zF9AJxDbRz<4*%7IE6xAu!5tQW9$c0#gi?kT=)u*29=s0d!7EsS9$Xjb!5@Jh9Et5u z4_ca)G)k((>4c`w^X2$0zoq$l#s(I#uhR=n*QxN5`S)U8kk$Vth|8Z`W2KyBb~f2 z%laOa3aFZH+;?WJ4%4k%c2dx3%^I#|&J4pKiVa!+a@E6G!ThwAGecI4{)-vEnCbY| zc>9D8Py#$CMorEoU}ua>aa#xDDXkze8`p$&ly#exzDT;HXq3XmJAb9}-=)F=sr z_R|nyYUBLG+n85z%gOQXlh0^L*P1g&U=`aJRFEA|+3kIvmS~nbBFOWw;^oUNy}j=! zq}V}>P8S@;WDStTvEp((Z~QuZZ0Qbm>)rHplSJ4!5uvwhsh932+Qw!ug2)=MIuA%s- z2_o$AzN^6eN!u^JP>+1 zwCxJv&qkul73PDg^;v0blOnEb%*-pHW@e%A<1zvJ1oed2N)sL$LyYqVx(f(ur8z3$ zZTB6USGKFI?o8ur|JWLX{@xs;2GDl0XYwyKEuDSL(q|n;=h==TcihCCuMM)ak%*SH z6?St8hkQ^~rtQVZ(jYmc`v|TL+=w-yVMmN?*-df)yT1N`g8_}v9)Tp(q;KHb9WcBABCQ8}S0 zrDq~TkAPv%-K8ROpWMDISY2HDUYCH`?lb&ndy%43WkehvvuKNFlY75A`hzAJU(_3AIp*0c2sc;`pR|`c_YgLWgb=Fb?Zy- z;h++zqOMM6%V z54dr{`+NoPm<0QLBM{2|<9a$v^Jey1*Z*!5U=hpRA*mowUsQkqAF-qg8HuNUAr5p3 zSISCqh_ccb#Znqsnhj;R1{)ZtfD32v$^vq(?xM0h3#Wu+qeVJOWmU-vmkvz9n3Nl*ATvtz?;S zKnMcL1uW#S0M}VMBh2(u7=)0o=BHv|=*TZWS98X9IW@SDDa?;LvT2RntvAOkK^DZM zhn)mWzLf``@6GTyF6I@+uPv5j`=RmJFG7T2?dy_dBjDb#T}%R%#jKhvWbixIzn1^Z z41E^q$B=@f`&1|hgb}8AcOjAwl0XE& zBa}>Fgc+hgJbk2;6N|w?ArvfY{YdwrVhHGnh>|)}gOg^BfTx(I;reK;oq6=`#gyZI zrvNKTomgh^iU?X>Nq}l_j@D-iH2yv314Bx9n2f-kE(|ea+jvquME;K!*pX(R%g;J@ zIts{*mye) zGDSgEDshUK)1{g#td@2fm7%4{pyn!pf@$GZE`m4RPFnsjbcQER|7Q@5`@6kTGu;{#Je{vKCF)cq8c|VQnd}ZzmR=o>Xn$4lC zeypKTDp=V!1j!IaOaG*B$dk6JTBVnQDf>AGEil4Bz-!mzmV=0~5lWbGE(SiL{65|9 zWY`(}O}vcwbOsZ8+sVYuSs=%J|Mgv@6oWep4lnh*$xVSG>0G&O)IKE?UIv)mss)Zk zR}?&0vMmztr%kG(@PK*401~;7iB%2~+hgYWkB-sM44@0f`LL>JL-8O2VL2^sboPsj zn~B(g`D-SMn1M1bUfz$ycQ+dyUrA@xaUG$Z)Z*-eB-FRuMDepTP#4f>loV3@0&w<{ z!cX92VT4145>|gS#VYgI{tS1FfZD_?x<$`*FN^r7`1x;x?xwXJI!!IUa)UQHp?-p3Y^Zp_RV|oG4018kA3s;jm3TfxM2{$8r!y8| z>Y#ou>!*M&L(#7}wJxapg+c4~FMT}Hb;)e;TD+WtNgj}G z*WhI$F}ZCBOe*xf@==3DkklfeGPe4VLnsAV%EXA!KmOQ4XZiUwMfr4T!|Hu~e)WV? zSA50Wn6g+HA>WZfVp^17H4o`}^3rT@P|T0ge9w~+pZW(ipY`vq6`;hm?y;;()`~jy z#Bdm1_r(y_IFdnnRO2hggf{jtrv&;W^b|iUDgZp9=SaVa`PtNU)Ld2nX&_KaUe*~0<`#`k$=9KZjv z4KoqIHZWW|E1nAS(iH*Ouw9tk`Hmj*FV?V<0$78F_4VBu$N*nAGb=6+2)o&JEo*n9 z^!5D{Rd1#4YoD#jGM9QNEEEE>lqgy(Wn5MprLSX`+U(^Xu49#LDq{ryKxSF_V|znZ z(>z}di(*}hvCcLH2@9|WKhs$>*iS5O_*Efci-rmGOM^x`MsFf3q6wYqf`wu0mex>C zyx7M4{w~Z}WKT*&24J}yQztLKaw{pi3w#o~H zGn);!@^v7!;<&#miHCOS6G5ip{<8~Aykx=U^H;0S#8q3d$3-IO`Jf?dE;eDoBn(qC zianne`!Q9lA9hBK#|YX%6^$`SK-qv}@QTMrZ7xiKDV{zVBg5aC7&*WIso;|+PSDV{ zBSTHIKo2*Awiu<#5F;)Mp>LUnsCj}$B>@Nt22bdrXI!{UZ6++9(H{ob=WuBVn5#{J zrBnTL5LVHJV|&|Qn9m-mpuY;<{0FdI1wW|#f{n%GdIs#;S~a*RWtL{rsDVA(;27tu zzgRTRpZyvbWHEu2JKApFZ+fcJA> zdB5ggyib`JA_ON4{El-E;C*y}_Y3j>-UsRK0ltq1`2Ju%;QM}ifbWw5zQ0!h_>zCXGL_&yup`|-+v?{oj{`*5s(e4k4R@O@1yfcIqq-uF}ict6();C(fK z_p25G-fzPNcwhZLc^~xZ`|i4c?{6gmzV89}ew#kv`(!n*zMuMUzE4mG_&&v}?=u0u zKWz>8ekS1i6U=}6z7*j5|KR=1CV=;wUwNM$;Qb3ad5E`L0PkZ=0lXgt@V=xY!22NW zssHqSlOn+P&0l?=;*alJ+WqnUY&*dB@1p#PkoW=L&+G<#{}*t#P+9@N_Za}+$AAKO zU-@6WkM=k3`xs6|M+5`B@9@g|L;&xb3;?{J1n|CRI46jQj27_y)_?ha;Trz3{t5CY z)-1g4llSq$)sMx_SWT#%L|Yzw>|1MKD5&c-?vxzk_OBC?ixk#5@DcVrUSw5_ruzdc ziNKZzs@V#XZ6*+!gOCqOz41j$ukR{@iYQ#8?!m)oVFy?Y)o8rsGV7bmpd|^`t_NMB zvsiCOg~arzTDQYsHJn}jJs4SgM1c@WoNV1X5TWIm-z%))j#srGNZVpP^M-HH_0tFV zahp8fH#<^26^u>PFeM712yaS54IJxdais=@+LaWX(aUVuPy%Wus#37MIa+8-{ry*yDtRx%| zfejs8xvh3%N1`e4DXE%anI!R`sFj&Q4ZYG2W{LWYhV7526k-V8jX46FQn>V{G%lS1 zqp^@Eft#8nT$MScbb3+<-I_RDqY0rg8078ppfCLo$%-I$4X6YQ3|8wFQI^*k$fh7I znE~`VUCQ^0iu?oauC7(JFj*-aRI9>)Fq?Zg@-hztMsjC0bj=+%L@I^jCH zk9o?sDNp*?5w_>IRkLWJAL)j#=N#DB&jJi?9^I-?XVB=mMIKdW~>bhwjHmY^OE zRX>9M7t08WS$~6<5_@KR{W_^gn`T-f?+t-(nZ7#@7=xuLM+K%d>?4?r5TnLJ-w*YN zY=tu!?F^a@pkhFapwTep5ySko421?fW;zmh3`IofcCyI;3T_e_eJkm&XyJ2M)7x?1Eys1rpJ;b##Cy z1-|u^6f_KKGT=%7{?@5LIG6nCuYUm)q)pZ}z)A-G$Y^LtDP#o1o()1G zee+ERuuD~xrwfH$H|Uu^FChp&KuWW?B22jdRJUTjiM?OH?!B#{`Cw6(~Dwo^MPzouofdo z!({cvG7aaUI0*afy`R=K$iqql?4(o^GPF3EASXH_&X>!v7b0&}6qU+vmqa12NR|j) z)6oxCM+L@8K@u-?n3mU!Q3~$FcYF&+#>F3$96Sa?ZibeFG3C z$mD+_OieO?Flo{N!sr1ALq~xJWy=I0OvWgHFjB7wL-;R*86So5%a8*Q#uY%A%3@l` z4X;;(p#%^H(JB?fLI^+@YbpR?XslvEkhWrg!kkk93L{O83c*?kAdI$Dv_MS}EuWbj zfG}Bq5T>u-Z-l8RnSd5-^^!kpBhZJDJ22-6NA%s5Sdh)gxom)g!h2s8GK`yU8{ z1t5%>M)2gSAybE0n5M@HCV((>0KzP3B!e4A0|;}M`X30Bh#wJ!zzHCX!ykkJU0eTA z7(_r}4Dyh-9Pj{yshOkYGcN)Vh8sYb<^=#@N&$q?{u^NqwEiFrHh?g)0K%+UbMb#_ z1Q2EwKp0m5VYC5+`S^-3?SCVTy_9$@+Ca0>Jf~gpKR39bKM+2s&E1VrQ0Hnzvu1_a zd{*)$7l-#;hBnm_y^2ZGbYROXN$`_0_5fYGxw(ZHH#Y|25Kah9p(_D!W0APg2a-omyH;S34Te&E?wz4OPK$Ol=%|tGiZII6>uxSZ8$6{|VvG zIu*=?1%_W*d68&2;aA&ngLpuRSc!~nZ-#` zjhGtAQx(ajp`T5Aw-7p&lPNfGxd`f;BF;f#)o~e-%RPbnvI@t0G%=DPh);6?$(kCA zu<(Wn`wcW@3%@ys%oAt7;t(n{<@+zp;s+Co?yZ~Z>$h)z_22R}5i}&r|5l+gPUydaHt=F5m*;Rfu~BIB?6ye!6oZi74v||b4fJ!%@B7- zXz(UGB+``7gewV4Bo|ndAn7t7$8nyJVOmN2Qb3v_SO4CSdjH41t{MNN*4VwE(}(=S zGxDS_O{ui(MogM!eP&ATqUEC?rCqZG)8caqRzInMD*GjB>>34lM2Ol@lbgC6q(%dw zG<;{gv5z>j;cahFY{hg(LYnfQNv_(>3$)2^P|zwr1jJ-0!(=xVt9WhZ)g8r3n%3fE zjDfe_t$oj*C=>igO)t5W6a+m<6EU%>PSRp#h~v02zyvy~h$^fbS4-YEpPCdu3?t;!iUGA9-S>$pwtiZ3f;NnDO`~8ewm~H3PZ6bO6|82p z;7$|hyLX^eIB9JY80?RuNVJ9tVKwwt(B&!$)Pu{Dm)Do}_f3Z9byWfC5C4;3Tr~lL zaa|oWB5_hUuj7O2qtBq>0+rWD{zxs|D_l=kID|PPYP%BW%?R}sw8_-;I8KeMzKCiDB zrQ>Py^Y0HfqwcZ5#NZKCylM)A-8c@MR|@s^yeX%8RCL+!xzLlF$2~Mg=z*DE z_|rVK8Y$>PCF`I1OAH~Tzb^ydE2AD)r`%2_NvQ=aH;jpOx~qk=p$m)Q1=hK@m>t;c zn$&kePO>T2D|jL#e^IFEDj@@^--t}3U@o^! zC#T$F8J}LabVNuB*F)=2WicUE#zrzj8$UiM#c>o>Vbfu zc$cu-ng5lk_jCA3MH(EO<)lcD_9sUu|7Nqxj}DW0$_MGNuIEkOBcq=J-kf;ayyvQb zYuz_^)>3d2ZQJ8iNslc>(aM}ZM=awZ+>0ptLmaj?>yrvWnK0m$qSAhSNrzI|)vKV&vK@t2q#B?Drnv7`*Z za?iw*2>}CH0w89R6!v8(n&Q%MCV-g5{I{4Lgpg~AqDX_DQOr^SGQ(iQLLd%&B{PG6 zBeU=7eG~)Lfs@+$5KUX20GXWuWLA{&hs^v_{wZek>abzqI)Iot0Akh+h?zSeW(RlUoB~R{0-d78$PqGK3|ctvmTcX7Cz+k=bPx5*vvwKxQofndy`V%7m){WL5!? zSvNptjsTfW{2{YLMAbiH=AjaXmQn(UnF1hY+<=(v0Ai-0%tLk|O)epk42ao>|0iaP z+bv(;OR%48Z``Z?2F2ogEbBPpin59yuvCuK@5#P<=-_WyOV zC6QD|B>xSNyZ=!z#7oVR5bb1gyfG{iI%;*nfAy|)8 zpk?^N?x$rm0_pLZoL_5()nC(pg-o+w4c0Y3umAdZtUl-zTTeW%!O~*BI7pZ$8^tYL z(RfnHy$PKEacH7C-~C0%E99;enDrl+b+)=E2XD{hOI%3r0xNEJx3%xWb?Kh6M;PW#8B z06lEVc!zf4#A0)bHT_4}*+VAcEuj=iU$(Z)9}n;eC<7+o?Fmi;5-`O0Ixy|A3B3c1 z;7zmM7K-Shk_pr2Mk0o6$2#s6` zlTcr8F)(M?WE5F}(uDM-QUsCaG7m;AkNlh_KB>7%OKzma3I}IBd{3FKJUO1RLQ8G4 ziX@B%yuNRx>|Kr!F||MeiT~(ix)l|caoM(OP2mlhinJ9zjG;u-_0~BRCwjK0e;1a} zcd$i&D|>iIP+9N(IVHM!O%_lux>M9|At$eK zA$Dg-DL`snimcrB15h&NE-=x!#*du)$;`p{jU^%(y~{4rX9=xwo>izTgGN26g%rjS zX$e(a@Iz-q3pp}G1F@DA2rdwPx_c8suOW>5(F}<-Cy`F%>a}k25-!;< z6Lv)qr71D&kID&-Yx0v&TZ6Frhz40gPImSlCA!%Mmt*AKa_ilCNI*i&R2r$%LCNz^ zmj{>j-%12`4ZGK%HhQi3;VvSqdfYB5HTLh*%{nbf>1-P$snfmh#y0uKKzMb$5_hq} zgn5#QL4Hpnn&=Ixd+#9mW#uTqWz!Q3-DGk_2=m-ue0Sb&ohrHh@u~+cFl)l9O`)n1Iy;PDDuD zR=!I>^*CmeM(0~#3-YV_+x2He0Cd-?XSF znG39|5=yEt`3y3uU*-hKX(^P5vXrN!CCvi=iIPKXEjcO4aJAnG_jOiAaL(Q(+o@#z zjCDH={Pr<#J896@Q%@7A;d~zr(#~feP2iV$^t6V7+)?8W*`d)_1mMHluvwT#{*v#JM|Wa$PFB9`R*8bM)$| zA0KsCp8`*3yI`^y=pN63N1O&+ay+sgO&1{BDyEqGJ~;!~R+jRRD9stjw&E$k(Xum;ZD)XRlFhu5$XonZw%wlm zJKLs?-wW!~=O0>gCVgSsr)3B2i~`{{UfEq#cuHy4ClkoF9RHndnYNJ{w|aqWi#P>j zTi^CKDBrtZv+cKk%eGPM0WnX&;cU}aAlo|EAH^P;)#8j#{>iq_P5+T?#WI4Rz1bor zK&#e3xUB=itugaa#b8n0I84UA`7m&?nmR5m+?>j|=*NTqI~9H_{~m|gEG+RKr>e!w-1B1gQR0gbT7dMrij_a%7&&FDEq#awq%HPi(-W6{q(#Qcvr7s5ZXu-<)t+7asLH*P>7kN%wV|2F^)Wy) zt;{U%YZe|Lq}9$9J`wyJnWps5)P&nU#w zYxG`KiCJ{$WcWPU<)&HLZB3}}dYeM$Jgs+r$Titmq?fvWIQ(sS_{EZXE!niQ7yB`P zXxUF}xm{7gHHwzE2HT& z3vEr^;TlHMo*GS6Al=U<9Pkt^C;sdydwiIn!_4!|htYiuT+oe``!KWbj_^nk{`7TRc!2t|P`Fu6|BV_&$LR;^<^4 z)Z;H?S)AgE5<$%RJe8T^d8xw5aJPiRq(be*XDyZGgljDYJLN+h$a$Dqbb?r%UNm!R zo~mH8e{jEk2miPfm#$M?+c{P(ci%qPVTU>OjWiaxv)U4H`F71trzywU^usUnYmN+A zV{1}&UwVZ^r+D;PMfLb(Sw%N_K-}cvUe9fG<^7l3de+O1ah2GZGF~BYEz1%0lG%CagR-x>qbqaM{ zW$C23GBl^x`aADu)(5uqxfx121YJC$=NE!rp1r&2o8(WwUQ-Y(6);RbfIeqby?k`J zHeQ~5y3=iaCU5On+-Klc@u~bto?DVkc!9ZiBG*yP{&aizb!gYd)-w;c*>r<0@OM@8 z>9Aw7&*R;F2VME@ofGeAgM%Dx$|FTU+sxO_yid)~(;@R2C#T!1r1cKPIvV*t-;?JK zx=$v5Szc>+gB%`)lRrxo8H1i$w3)s&F~kf{9*4B1wNETL)@3zWp!mo>gSDXMCoHwX8@Nc(I^RuXLNRXGkuyc>HZj|;vUe(mt*#IMzI9M z@8wgmq+j4!dkQHmJDI2OIfNmmebSD3il(~e?u$W0xokC1jT4eh}PqvZ2NhA-W3+r_EEt1$*eZ#0b(ZT|?f8C?E=K{9AE-IX{6{ep?H;*ugpBfc>{SHoV-ULPG zF?g|y@w#5J%}@E-bxYn(FY14oAXLW1wsfCEyIF4A9sZ$q*MSoA2KYkk*efn}u{33JW zKqKocRmk%FkdOEayUu%kw&4!kkOKN!nL(G_dYrVz?p;dI^^^4c^xm1r{wI&1avJ@g zCBLkGkHTWVst$s~S8U>xLdB(_^t9$HFGz9f2Q8s=GLz`b~T)7XM9GjmAG}Ar0 zsW#eS?TTL)6?WkZcq~#gEJDW~RnFI6b>i}WG{;DrjChSAE zzG}y5xJd_2_;=(C%B8O@LMKjEQ?6}cDBZH&3TPi?ImrAfdj&cCS#IE%<-E2c`qb)r zzg>jyJF<+yf}jrimgYCiU+24B9}ZS2eHbz*4~B#E+2k#c*Z2cNv~T6Z;%q(@hH9!a zjZU;#<$6qi!$GBtj0=%l}=~HAv=OE>$j^3&Al+j-;rqZqSdafDy7HU4$9%(bb z>3u{iZ3bDK!HjUf1|`MgGmuQU5HPrcQO6+eIs6)*p3(1W$rStcHc52(nNMib z3@0}wL119!RFW2SAM;D<8_Ms4G~_DRm4>7Q{=#6r$*y!d$GarNW%*wa4tl%K`tPUK zd%Jlm;;6ehc%WcFHf|%6FLO14(?{TtCuwFqVAu%|EMoU>gF*tGd}Q55V4ve_B*a5e zNPFC)`$N&@@W^DgsX$;6Uv^MqOCi1B@%g>+e@tE%%jl>o=^QDTR6LEISe3u zR276EV^ClXn&pvUHR@53D06hw82a^oU`e+fm+b3VZP4ArFvLPv0MXCL4~TwxAib3J ztIKiVvbHib>+myED1^NT-qd@dE85v;?s2XMlwxh$Od%qqYiZ`fq#9=u5@x)=qxmmi zoI-&ckrIQZGKK`yW1RR^o)8?q!3VE58f$)~SagsdP)Wx|oM*-=DLi1%WGwZEvg9 zSDA#TyDSRbcJaNOwY|8sbD}3zKMvJbUBGIGA3SS9F@$_=TjOb-o2))9KCw61OkGUc zJh;^RZtwtxB98oEA4rTE(OG?^J=)>9gGV8Y&~#fNnd4sSz2wvLtwQsv|Dmv(b(*g! z`#r}kh~(qF)j^|99CNjH&G+TgVymb11BaIz=aQc~OXY&^nKO`s_0S!^qpl`6tNXNM z4Ya)oH@=ns0G>pp*h)6HA&;L;)^?S)n;_84@3P@%etmO(X<85BJAe1<XwU&(}sUOWmzV`*$@%#7$nhg{l_Ix$dRg1|!z2b&7UYiy@ z$)JT-t6F3=TI$!~Shuk3IAl>6g-qvrGtdP*n@j62p{X<3`BsU;a(DEQ_Z3B+5TFLD z-yjhBbC$V}iu3x<7}*2>Wh_b-C(CDyZ1uKvzMUTYHb^UPTAV~&|K1tF=k@F9pw#2p zgTqUhrdif5#jfhkjH3z!+UsMdv%|P~YYaAL!($z_*_XllT>Vh&&8G5%iEHI@P2G^1 zq0X_KB4bxGMV9=niwSv4_wzNV;jC%#98{Kp*cq{@ma$X2(NPgo@7fDHh^qB1cm$6Y z%xP~EdfpLxz#;AP?)m}uZ?nB9J7be&W3stOChMpv3Sc)cMzQ#t!^>xpKlAI$$qClT zmU{Pz%JiA{q0io@_Q@Aj=DXBfu57ssOzwh-romh4j0mp?9&hKH2lnW)T{GQ@S!`bxLeN}e7 z-@^OylJ$*ki#w~aU9Yxtq572!~fe&@H%KmEcYz9soE=b=d0&g&j z;flIW%a|tc`gR$SM|Ve6?;7zb#v-X{_10)I$(A*rzi^q^hpUnQsN}d5G1D zJKxr+^=+SBhB3TaR=N&DOXpbm)VJmJlgs7)xR-73x)&G!Qi^Mb5?PSN?8_5&r! zlb$??euD=bM)PY649(8aGQlZ{95Y{M+UKmxV`S&NkM(-@D!cO;nuoaAn?#g&3bkX$ zV(PqZU6;pE&VAsQhQ;^L_x(H4$NZcUpCmySI!#7%RkKit4@X{Kp1xVJezZbYpf(qwOLQPS3rQ_5*h z4Nh~L1Hb3BOw;7(`2EexXkZeM#?^%LDQY^h8Ap7b?d~*nJu$ zMD}KmIfN6UIA|JLPIQ_B2Urc9c&WOy?tJ$29>3swi`ge|dS&43ou1}1a58=X>*`x@ zwkAb0)^A`1PTtGgZJpn@HtzB>E!F#|RCIzwFq;mPXY1Jy`8&6p4$bpIwZCO=zR3Xo z`LX`(SU7owV7p^~qI2u+LU4Kw((bp0^JD((HE=gt-CtK{;0z#3GvqDbuebH$Y3|`O zcgvuhh0LD^SLd6$U`Sr)5%i56^asy<^6Up?EkCsRzG5AscuQqGiB~?Jprrhs(beDD zKFDr?u;N+r%;}n6RR6@i?xATGv54&KS)Ql%R8zeKQ~3!}97R zmo|aw6L;mx=5|L{-Q!1^q{ft^#upDBOeY^c*~Y@t>V+k}yk)kZb_xY+RnN!yG43gZ zjg!A-yBIFkdQgtG3*{DT7&biTgq7Z z@*HXstyigP$0Z=J_xJz_@+vc=qxso2Xnq1e|ETEhnr8?!*|uH)@U!USXc+pp-WlsW zpX2D{cC$w6<)gw1jJGWwaiHgESymbU$@FYwiG+Q-6Glpbg>NI4DccA&2**DRZJ0JQ zmDt8Sr<&5JaAFrao%wj^%i>4P(|>le2YIm+y`0Th2o0yBbv&MwSzi$n1fgwgc%r!( zG}w=ZV2@A~Ko)NL5o$_#UKWk?qRiDqT#JV>uPwP;d}LO)w(I7vLpSeJ-ASu!eydH3 zdh~DS=U%siT$f2l_sk;q+@AQV=`GJ1V!C!P*!MzxmOg(vuohun@M0O+zQ%F5?)l}- zk?|e-Hbq4g2pFb9P$C&G)GUoeli7{(liJh=WvaxeZN?B_C;FCl_qG#%+~GwYs6cBt%#p}-P-<8S(PD#v>|V=CNmk&_~&LQ|KOW1 z(l^=C(gBN3|A}lk05bKUzUJ4ZgOW{Hw{9+OP+MRB(E-$B226Lcx!#yL7X$IzZ zY&94M7ecHX7$!1~sVO~yPt!|j20t=j>V#>AXVgrR45lHQ$V|MO4tb%qO;GfmUfF1% zXX9rcIKa*j6_JSXK&j%Sqi?zgCtTPxzaq%T?Fyb2^OwZ%c31B)!Fb>_iE?%>p7*Ei9KVAR!xHX!qRMaXRli#ZjR0e!O^R+hE85 zYHry7NP20q*0+q!(VNPKNzpk&+S$h5=l1j-)8hWH}Yu9ex+yOPJQB@`2 z3Sbc*SmfV&^lMg#0Cb`G6c<<_3)GxDE9T?;H^~BOFYlKhcOEm!nl09=A^&P&(c|x9 zB8HeOekUzUqfssCV=1AAFwvK%Ynto<^$a%8$mL?PbOJ0EX3+A%Mp+&VuFq*QZbW|K zsnrWoF*&-G{vhWYh~Zqbae>KH0-Am%0c22*lYlIGRR@zcy3e?O%&e|8tWRkORQ=f0 zrP*huHqW3gQMV?mAa2mhe9?b|gaS4F`K2sPw0=~#J8!AA^m%aBWKbBlC_X>oGO=~! z4k{Yushb`T)eP9nw}DZrcazDjpI)>TC#07A>1PcsP=PL`@;(x+B2GjyHzy`h!Doko zUax?k5>oH`SwfeIuyitReokr4|mX>)W5C~S4X%y zFjwvBjj1wy;fX9>EALcCYRE;qj--YD68Kz9B}IBo9UB_$kGfIS zO0-8s=0R+ldM==M#AFGe>tE6C!(ETyTntBV&fW!f_$2A+37Bq}&8Z*Cjn5tPXGRG& zqPWJr@OcYPvaEqqnWtsF(YKOJJ6_3J(5R{zJ@ZnRS-)O5w(Hv|bNNgexC{v0%ClOx>sI^WRl{9@GY z9t5wSY9Os;_U+!#zrE-rmx*SKu;256K?3DrhMVtB zrzI2MJvKz-O-to!J?r`?PUoLgF3oQFCE%7HP*b=nP+vwpo3W_O{cH5`yq#q}6|hM9 zIX>tdQxYW4$T|cA7gG!){<%+gdCV=HAkh(>SdR?QA9di4^ z8Ebly^{d0IE@hHlM3*9k5FMuwd>E4_3Y$Ouv!y^v5g98|$5 z(Vy)SGWyFmY8Uf}On3nC4NGQpIq-~XfH$__?MeN=_^7MLIdd!F>fPRG`9gFv0kjQqpisbaXr`Opv zX?Qpo-7^t0X6vRU`m>?hl}K$nUCQpS37Hu=iyo1ad)UTNFExAS?dK7}F|-n z2R6!Lq*u1%c2&2m)3*0XhG&2m@cW!gVF-YeN;W=Fi{@FqarEBKno&hBMjP_ErgaJ3e4`o7xH*-D6-^WzN8j zf;L#yGMy2lH@0Nz={-go#>=Z{j=(~4So6l@q&5R%2K7r~lM!IK2#t|*)5Pk}n~8%m zQ~XU#^Kr>^m24ERjGKuL#7szOs;25 zBmNkJEgL^TWXn57HkpFym=UjRVC3Q-N*2veh8;x^Tr)3~fcND7+E`nVf{SR*=rcWJko{f^JYyTxCR#z@azpK0p z!N&Oq_qu*1$>S`_vgmL90?Z|r311jI&fKAgH@MEg_xIr7KxA;*(><^60a(bkU|mwP zH|WphXAa4>*wm}CN1?#TX~^sydV=lV56EDt$p3-k$ArGy$GV$2l)tKp)XocBU9hz#mLk@a! zZp=QRb?o;oNL0o{kWc9#lhtx1QT+cYIC)ZM7pJ@^)6BeaBzrF%fjX2uL5fxYW;VL> z=$$K|bt2H=Z$KgloQ`mX2p(nPSF)Ip!*!<0t+;GP31SHL?n6ScZsvLd5D<0dvFJ;m z)!!oM0KNymtD(3))VR(jCG3EWg^59~nU=!nXZwe;+#P7+=~COhCBvsnt?-Ex%bSES zl5#Lze|z<)GmCJ94~*FYFhYI16hM`Il@Mq&R%1MD3nmc%lYYKO%R=Y8;*+UBNFERx)_6c;GURqaJ`i?$R{oCcNC%5!!&l?UNrWr8|tC-xv?jp`+xA}K_O#@>fqb@8^@Bb}#9gYLnbx58W`gFUm zlvKuhhpRtJ`ex~FmCwr`S(3*bcsQ1&YjtcdtjW8Z>ncd6cyDc*ZuS^V1}5t`J8P#b z^?6^CwK?#Dh>Z%6nYAGBYA$uZ$PRk=-V<|pgZCn1o?~x7UmA{+>J+byDEiyu&gL4d zak-BA00uIx_x>OOW{_T2@e{RTGM4XD84#F$P`)E*M8@DT=K?`a!D)78aFx|uPn%9E zdxw21t5>H2L6GVQIVP2adPQ%ypa?~Fm;~Z!QB`1q;QPXbcHbi`D7fH#ej2bP{3W1c zkE$>HXxR4r{D_YJQ-^MCsrrFCTYSq{ygrEaj(o8{n59K$^H9@?{~kBQOd2iBd26ry E7s0=!4*&oF diff --git a/public/api/qiskit-ibm-runtime/objects.inv b/public/api/qiskit-ibm-runtime/objects.inv index a31b4e334a77ccbac2687c8674d9194a5ab15a8e..383dc392550d480ecdf0c288845307c2e11fd7ac 100644 GIT binary patch delta 49028 zcmce-Wmp`~w#JLQLvSa!y9BooG=T&S9^Bn&EVzXbAUFvyI0+C21{oX@+=IIg?ly4e zzxO`R+4sx&cJGJoXP9YfYTkZpty;gXsvbk_nm|pB1BQJU)Ei3{YC$I))0Ee_(eFXQ zLDLH_yzJiDZmqnsyG@4B5vWDDlw#|?LK?XUxT8i|w?oHD%ktvu&TC`+N_=jjz(ID? zqzn&P37zw6f$P=3xbAmdnQ}9O!mqb4CK&d`pRU+~U1n!?YVUXMEbn6apU$>V<=}9u z&4q$W;OO>T;PLkLufv?DtL=U38baXytqf3}!q1|*6e8QUn6<+sd(#&@I(^zKTb08n zeKq48qi0f^>m0nB)NHn2GtV&ZQ{RiZl6AasJ9TiyZNT@>3LT<;|g%B1Fe=x&Me7+8wasa<;XcJ6H6C~KK4xM!)O@9sVx zx&0+eI4clK`;u4tX`$fh#4Gg5^*zycxF1_!%YuwSOt-6F?W6Q26MnO}-{r$~C;-&> zjTTgHoIZv+GjFpTvwr0E28WJo{S7{8`?1H~$LFjo|E@mV&r5c8)ZCY$@^LIgN%!DK z3spBEPieZ<;!^tL>BgfTP$MN!LJ4Lrc~L;nvn9q5AXg5^9HbQZYF);gI`s|&3G!dw z@HEP^It;*@7k17ce?>w~4mw(xb^y4+_5zgFPrL+`dskm`uFy-&j~)KjujS}H-9op& z%<+89-P>a`LO4j~Ov}S7I|%PSb4jk^+@lHQ+GSyu-|%Z@_b~?j!qK8!N-_W1i)M5s z3Xpun!p`WWJ82{UHOoVf-5G2%x6y-pUAM}~UEdQVa;h#Tl~Re z1g;oEt5o8!5vjs3)b(ukTz=xvX_LqTqdMye_E;ioec>?Gw%6|z^zxa9;Dy;t^P_*w z!l=A5;!C#aZ*7|b{p@Xl_q9etJ>sSsf&mFDXw~o|7nrME&CM4ltCve!h9y1+o8pVf zU%{0l1&$|Wlzmk>f!6^mz93=GS}_`b{uoGGTY$;^@kZvOP{@_6`4{ocuJzRE&(P}p zmNj>C8M%TxYd^Q@j8gwBt)H?%CHKa7ZJeF1CBM|)<8FSPoXo2PtOZZEiTBl4EvU_4 z8-wmjC*Vm^gZ(ZM7?s(+(vm~wq%)4hy&H&~)sM1W_Iz^f;w_yo3<%><9kn%LkXy{f zBTon_J>R{IJJ`1xR5x#3-3lzLY+R7JJQU{|#xpON(_arY(G1&a@A2Txb1pS3XxpF8 z?H!=uKZ<(!2nhvbKeC)BF?_Datj#((9K3l7n%XLi5wIVA0D+*>qf1BUdl%?z!<~Y=0A_=7p2QkX}_eQ;Gt|=z?{>{hq%WH;kn>b|4vFzJx)1`y?yI)eZ!Bn2) zqBKyUGtDnH7&X6dbpbst?wA#vhouYQoyU^P7ALt6XHWnN-{J>uC(UOjACE3BUKfmB zW3N0O>Bt?2o-fEfUfeI;Lmw|@&6lmIfEO}{vPUW1oQ0JTC%H7O#XsHkaZLdq#Dr^| zW(7!B_UD?i{QPPb9>)&nkKP*$Ki*&yKyocj&x%6B>j^I7FQsNbqndD{x~L({FgCbn zi25v%5P*vB_`4iuLrl*}10Q8R^;N5fXUHWtiJ!M)FTyB7s6GAGzr#b(2JBFecUrG1 zrG1D6lbhu(z1v^16MjF^l5;i++LXjcJsJ*@2yqNI>W^8;sV{Fif28^<_D?IYfR%%n z$aNLp|2!vSIqt9e(x}qqV(PU06l8vV=?Xjm{wUkxku$?jfsWTs*#vw-6CFX4lcN|G zj{>Vlt?<)W_>Xv&qhUPJ&9Aq|K3j9K?+9i`Lb})H1MWe#DLlTE?rzI9cW6hk8?ix? zSGCZu2^R;(-lCq8lIw20QsB`J=@d zvPn4GyXGf!Eaps3*!F_T1M_rk2@(`bc-+u}IIZ5tUh`n=fdr;3~{5n3}hD^88>x&ljzFf}UKKl7W?&wOyiLlI}<8aa;-*4;qyW_0Id-7v&x!InXbNmn+94ptiY% zG!S~I|Mpk6r$x=rwRfMs+P0le3XL@F?`YBEIU z@dtauNthq8T}&1Q?>h(JsNgXz8Qx)&*>5T6=GRhc zep=aR!0sPQ8rE!Hsig6qQ_?Tj;vL7Y!U4z9l83i`)|EJ|xemPNc!p<1vN+|FyDf43 zYYRn-qyR&nSg+-NAwz8_i*z8s{yxex4!pj96Lc}?mUlAH=BEfBy=yKAeLDUnMJ~7d z2Y{T{*94y|m>1lEl;Dp)fSQ$<0Jq@&MJi3SWGJucVanmrFX)0rP*6pT6<73D?}Ot_ zp4L9WpTS{sa%kkK2e7+;ezcdi3NVbv{NN&4z-D z=|raNIg@W8iN)ok-u79G4i({{3@ZxwJpHutI?qT13>&I5IF>wjx9$IGCw#BP?JUs) z2rn{&iNx6<0J}$u^)!C3Of=2)Gw`|j$h2I;i3bMToL#-k$EC*01y>Uvs7sqzyZ+zX zdGO)hq617|q~rOEgJ9m4%U|?C<}IP;K~K$r)lYYaJ`aNDx<1nt4bqP9F#LkzmJA__ zx;WyW>A{~i@ry^Rzk5z{Eb)*v;XhKohk^qCen>A+5r|``Q?5cnO&UTFD7ObG#coXrmXDQJL>0~p1-Js|Gd*ZK4^hIPcV8Iq>D3>zB+WP z;J?&~(Ye11K0XNzp(T%OFWH@rn`!Ib^+~?TFXCR&IgolONR0iny?R}?f7mwxfN=~2 zeKCt^dYUN_$I|XkX-Tufp*Gld)wr=u>io zIHgqe83CblPY*`Yhn1a6DYTPDpceL{!!O+QrSFrLr9o#i@3U6L)fWT*bSSz`oN)#U zJ-`pkaT5=E(RwYRR}&~a52HOJ|9y}$_F{H9w*6eSaTfW<^{+N<_iGndH^z=*wIEdM zVVbELd5>?5NYWGKyO+=%FPXb#e)yucpH$6oX_vxGJL|Dl6wUEikPIyl(!C5rgDpd^ zrGEbbpSKaXpD%^DZC-V`EKIM2H|1lt79CwKwj9?6u>kKf?~-LPt73P>xRzwNh(06Rpu+!vy_g(Yl`Sj~pDRpRn4f?|AHk=463;h*mBy#okQUu0}DpY>`yp8`iTA97d(-^YYdzAe2#zBk@hmvqE) zWnb}W_wBctquI7II=uP8J*p1P=+e-wE`wKop2U&5p4fnrkS8|sGf%O0KgpmvDZaGb z1-4&y6?}XjH@Nti2iW+81ep00{QaBI6djvzDftO7I#~;FGvDjru|H24zLuK$bT?dx zbu}z+amL&Cq6s`8UkM)Q$^plQ#e>rqxy6HGeG}rceG+~rdTXFnd1F@RFTB0Ie`!;(z>HC{KoVKAfY4@v zC-&O{4|>f4-p8^9gf(S-{LZ5IBm4TLu`7Q$=23gK1Yfbb%RL3lqV zKzO(GAiV#rO&Ngrx6%cKI7^K^s(X$95ogwgIC8=TTM2O>PrLkE8wl@zv_Z7A0pVpH zfba?lAX@j|ZA4StZ~R|vF0}F3dy@a94FsVL1fdNCq0MgNfIO^mpbOR*8@Av0Z*5!? zfVgZ|ggCAUaav^<+F6)sMC-$q=nzehc`uM; z)huNEKnF=Apeb;<;I{IK0l8}YsE6sO^hTel!(2T$; z7^;ZI370bD)s}pbH+nl6n>M}H(w5`aqW=E8HH(qb1yccJ3ScTM#Lx4`Tq38kUm`d1 zUm_=dy_As_v}H>;?jrbR(nav=xJz8vv-5J zv^fS9Amf{52s!fGAaZQ1fD9tqMZl*=cLtm4Mqpp*3%Xee8(VpQ zYg-~lOY&|Xb8>7$Q}S2#CgjNSMj4(#YmNA?Z3K0MYy>ljY&Z)pK5$Y`d=Py1>KY&8 zlpddXRF;~^CMcD+qr5x|LB|2O;MXpM#cox`HDDn`2<&uN4CMPv)tv|c!^v)csNBnLb11-dGs1>v+rF>|%3NMJgE2l^daSd~X@tn~*KmRZTPS8T|%R&DSM*PdauO&Vp) z_{a5G2eDr38*SSlDekc1neMU@sPEYjQIux_mWI`S*qi-bmJ)(Lkg{K^BPD8bQ9cmF zR&Ccy#P8NK7Vc|c(bw^NoIv@;+hhbRQ{*N%CEz3@Yz3zxoFT$KnfUeMGBj+5LvcVEy~srR9v%qEhnkSAq) ze3OKp7~{+nrnc0Cwe`FETa(8LQQBf1QPkgTFMoQmS8xd>60}V`482tHZUseSa$_Z9 zHZx^ovbQSaXl;R{3A<`JRoJgIIyinuM14s^M=ND@X=i5RMJZ$BjmQB|+9qo&0QjwP z)^7=dgz=CMS+VaveNt*n{S--@>V>t{T;S!d1GT4RL1UpI4L_hFMgLC88*M?si^@Ze zAGuA2kN%xhIL4kt7?Y2f1?`y7TB?FT%M<3MqT3~4ZC@jx)R8T~gcU8&YwanZ;$$XJ zBCIYT=xw}3NB=iA4xf6@?vXj_IRMZ2@nHq5+*j6)E&(oyFi`UiB90gj#8wmx#70UF z5c{X>NW|gz55bA*u_S!U?PV593wx7k%h2EoPOXgobq{(7k5(Ud{m@3?un-|=gwL`;V?8Yf zD*YiT!&2glts1R&cF|h8aU6@oue6V^ozN31W^t&se;Uyn)f>^P{<5J|0o&lbZ+?bW zz4Aq)LOkL7zBsNDheRYZ;2;qhULg@#xG$m9$tl@AvBy2`(V3*=*{vMp2*G2ifY?Z5 znu0Y4I9pWIW=p>74=JqJP-?GHQEF{a5gBfMA!?ibnyDZ7wclpY=Gw&QmO)9oM_9h9E|=bA z$)nG<$c7O^teb0l&cE6|mbUd9(|XT3O0usH4-s}|+yOa00Xqe6LZoSfbgo%0@~cn} zRVA#xG*!_=RzeUZfXh55NUogtK|~_nMufJ>mWRr?-zkeM2|d-38kbg4)R^+Os4>x7 zF=MQ0F=GO4apUX}OHnBy$mxJMZa=S!$8kS%P2H(vtr_PNK@f=z~T^ecx5l_z$7o~ zaKq*rQ7d?H+l2C@i){W|Ub#M?LojDnmWc z3VYVmYiN4o!gS-X6+B`&88Tx8%^RXWg-v`6SGbG{4=0LZ3A4cH|6qvSH#M`dzwz8c zp6JjVspHoQS?x_bCpB4!UX}e#=?C>gt=l|ZkCW!9S0PZ<7-mXm4;kr{fq%=5CrZp$N2@DTCrkWRM;TFEhxemY2rs)# zh%B+<5ACwi_ z#vH!*`CG8CiP;wy48;?r0VBp;X&+}usJ=IluP$cbm@yeSt6-_RAc_)KL{Z{4ce1>p z`HHJ%fXVIC&?85D4HwfDVrX`I#&32|I z>`3JVO2(ZXk|d71jhsjl(w zJh?f4Y&M7fg|fP^R;|IZft-#N%U2)2q^oSPQhw*5=pYMdMnZQSvMF4?PSmLw))4Ej zHe1+HIc*L@E83RE^L2nj{g?!EHgHh+=%tNz z8(-Hci7zqk#LrB5NLE|1)w4rZI$kIKB6*jVj)|7V2~@7@G=(%sCQsC|sRgsjF$zI( zF#jvG+aT;nhgA(qa}Xw^_2~@*toGSKWVZl^vN&{7y6Om@tZoCJEb(t16UXR7VnpD) ziW?0Pr4h}!jS@gZMak>Lh(_UrWr3W7EdtA?qMXj=P=;o6xR+BC`G2OadlQoFWs(U? zB`LvHtpARUtpANz{-jWl_H%)tp>V!n&Uo&p!p{{)t4*qdP95@c=2S$_Uo|7K=KMzI zQ+;XnEr6F4B30*thm~lRh!t;;cv`3_GTzp0^l2(OTyY5?h--V@5FtpZAI@ZU2{09; zh7xylUZ`Mc9}g=8Q=a(8II|fFN;6SXNU<&KF!nh#C3d!e@sO~=MAasZsiPIYIu!03 zhzQjivgXglEyDP49nx5E%cCe0_KNWnI#W?_zeZf+{LDJQ`ALwEdPx&WS}_Vw zI2xhhHw&RLc?n7dB}FF%rJfcA)Ce5KoPV-fESE@gHowSiqDTX6m1F}MR+g;DUc8bB zQlXm2KWWWd^{M_d10yv?{+%S|^+mlLqY^4|N_`}YE($uW3Cg-d{X8oLGJ3r;RTilJ zij5i>{j==OYJUAQ4pL-{QNLFTGKckioaD$TGPm`rT%Rxipz3O8l5}I?Oie^x+|_|g zzuAU-4sobLOd~i9I$05DGIp6aQeb`f^}zOUs=$7=GV!9xZ{$I6gi^g5I`;P!o`l^M z9$davAuP95A>@kH_=_1BSIP5Sm2sY2^l;JKP9o`Cg%0K1xLM6yCX2VZYr9j=cC*G* zwOvjO%ZW(YIJX9^P)W^w-uO_py9{Toew z%M(8Rkv~XOQ7}jrRVYkJ5Is`p9`B0$KVsyj0I=I9;gN~D$nvSp!rWj)` zrll4>rlmz8rqM_r^L`(dm?+E70b82C=eC>`=czCz=D+%@Eo^=0T-b8gT-$4$JRgpvaK}%dvAif6eb^d-@cmPC&R~#8pqZAKH@ev7d@v&f0 z^X+uw@NGHW@e&K{^9sez^9rs0aY0%2Sx8T;XiT3Ed>@i-m4KCPmVorb7{EP^(8nFm z(#8Fmt&RITQ62ZcGUTm8J+{2AZKhfsUrVvo+d1^CNs@4G7T8bhus7Do^5a%av~R5> zn`TGDig9u%d#VXnu9e}>tSm1@KUU5=sk5gW#QKeyB8Tgl3gc0rNW9l!vw9XT)Vn_a zoV|tir^J^pjQ&819h`b_m8w-TgxqBgIx9TAU4-wm)` zzK#7jHI>d`U(QLUr>loZkQU+|62xr#?usbV(o<_aPG#M{yA|oQi=%{2=g*z6VnIe? zuVY9#3!|MepF}pj?l_Uut~iTH&m7bZmL}6j%R!&y#dH7`WR`pa_TMk)w4;2pg-l|c zlGC+W!uE6f{1qkf*U~(wBi^iuL{+pq3~YH%rY>Vo`&zvH{z3G07RW&=_wBd{s^^KO zFq^jU7em>>$m;k=YpGndUXdQBXouKnbiLTat$MoZOac&iUJUctqt1j{5&M_7gk)Ap zcO0pPQd0t8K#gQr{eemPY}{Uwf^a&wZ%rAyBo*f2Z{;%)Rrt4AQY8T9dt~- zBAyugZ#>u~-|-Umi}7%oN=afZKqSajWzK;xpD&(ue+py!{)Da0b6Im7aj}G&GuoIX z45@9D>dQOpxL!-{t*bZF>0AEqGg-0bzOv$|=Gx#924%ca`{*0Dp{l5GLzH@&w(;sT zYMm1cf&Gge>jfg*>M66lHIN9ldEboP@s6Jm@F^5B^V$7_{l9JMmTqt9im~hnp*rn) zN|)~G)~)aBN^l(LBCtQQ>2N{ic{{+`WBL!CoZ!>!;c6LR!fhGo+=U?UWY53wB$*GQ z+VYN*&+tazNpEr`BJT|38Lw!C&tB0HZ@j)Lk$HVZo%JM+$n-?eNzZ@NNxDoy5voik zi)WccXvCT8g7}%=M6oj`sL(V2n@*Ct5i3r(Y5<0H-UvLIzVIJBIoOERS=NYF6x)b~ zUC z5av-xN0{ebhM~7nh9QTkFTy-%|Cpyxy&g@`po;PqPitD+t0oE&uV3+kd?Ct^?tnPF5_VE`)cw5#Axre53Zv z?|;36qkbBN!SyfiWFx$ji|`JRk1$UJ-`zVVYZgn6?6W1fB8QZ|^b*msx^D)#}x zJO{dU%!j%XWrzQmCmiw2=w8#l#S&4u6v0N8?98U|@d&bAEmq0$(8ux}2Ro#f>N04M zBv{2uU+gx03e)o-R+w-XEO_nCWIpW{9;W9;8d=QBThLzWUz!(5OU4U)2r*h|kb8!s;H zFT)+V8CdVBFlEG$+#Q|K#v1-o5^(>dT!h)l8-K*dTc3$J4yt>kw#L2`je^ZPse#gG zDUZLksG{iuKF=um(A=ByHG3RUY+`L1UTOMDTK(kWmgk`6?uo>4!nztWP?D;x!N5^4 z!C(7PM=cz5r;nriPAQ|TJX%xzP10OLKDD)isOWQbV@E8NFH=MnFL0)`a_@8spi`Gl zEq2QsE@HVjK0n^}1~=4jm3zCr(|v>DMD+@yo>5*r2&np)u#&Jg+e$+YvjyMG!${Om z%`=souv!>NlK!HTmh^4EtzgN~Bd)7bCaE&|jRLF3O`f@gY)8%0s*5;zJ%9gmIE-vo zEE2h70Z+NXO_*H0dpK4q^WEO=O&>dy37Iy}G_Lq}3oI4V+cNTMueGvld2pa6-}O%Y zx%%yJD)9VTyjy{Fl~w)Nf5!Hg#jCAfrno`B9P#WJo1}O=KExQF2?%*$Y+63EdtGeS zin2Y}vmsH(!I*~6t$@Yk`+GgeomF%TJ!6%dKTN>G=$i!PP+E-sS5}H+5e?e6t|J_Q z@Mx;>JR8Wij0TQs*oeI$sT68wy8Z9Mrg0L~^kRTD`a7l)e75;+YPN|lFIs_#AkaHE zX675|#~LMe9QDWytcgi8-PbxT6))J))V-pEP2Dgs)SYaxRP1a~-dnSwyfJ6PP&ZM< zd1s)Cqo}8i6_KA?XUY53^Pf5SWGb=ZR0=WjY%(HSCo$1ZB{CUKB{1bo#E1W9P7eGt zDSv4y!DOF(LZUt!nfX4QyjA|(n9bYA8!pcDdY+$A4Z`2^J)8gKHG!RqK1_>j-&gJ6 zV?{e|XH#R&x{ay$mT)#7lK*Zql7eG1RV*PY{c-9rn#R5@4%-K*m z7St~BzGHTJvemT;2)>!f!Ja4wp8!$06{ya@{(giC&On zw0No_hx*m?ydXoy$iGaB47&TQD*b@GRj(xT2Ln0(Gl4P<279pTKQmE&WldBJnJrfI z%ZB>!ms}{w4E0s7SdoE;4_Visy$xq91_PAda7q=uwyAzK!4M%Wu~28Nt-xdnGG<9} z&_*VbP>8g)Sg4w1&nF_4>t@+LcAGo@T&IWBZ?P;)@sGEIMN;i($v1Nn<~LD{aV*4X zAjAW)NjYr>0%5pxa1W0vEf#U^K1e~cH(@GRR{N`LN!WpX;yy50UdcRub1JfO!t|0v zRgr8b+ZkOdy< z0gq(v2L^p{!xS7pJf#({OYUAy>zj9d{vu0b3pZaQ&1FxDQqzv%e;3@h&i*-3^A(`S z(5J8m+R%_L`IyrGwU3Z9T7sm=zG7pi0#<>PCP!!cp!AT~`7=`C8@xzeqPyP`0xx1# zC`H`L5Pzx59skHra&&fy1#cv51(ZcZw5Cqqr^(WQ@Csf_1n?+NitD`l+uz;4;k*$; z_L4U4HEqm`a8MYr9F^_;#)TkiS`5Ja9MpJ6!Z(l5zd{b5VGV6kfCug#zZRpHwdrp4 zjqopD=>F*CPy8oZIV!tsS=;<@X)>mO>XG}C^AC6KS^J~iFY%NR4w<^lyc&EYYF9Z2 zZA6_4N3i1e+K(*ls0js2X!#t;3Zo%PdBl>gyN8k*^M#P$MED`Tkfb7c#6U6JX zT<1wDRC+`rR4r9=gD3)eeW?eRhCAK(XYH-@6M94l5U~91pIo_E6B%v)o~ub4OO&fK zS^#UT9Gyfx19e9MaRq`Rz5=RbPc9Gk*%jrIQ5bDp3;TZ$D|Oahy(+-3ZzC)acy7z1 zeBLaZA|@=2u)|2UENd)qW*BP^JiKkoA0g%lks6_r`<^j?7aiN)MhkO8wnGdQ*N0RT z#HfgOebBg?ghr>FGc@&6bxEXJ+~mB+wtOgl_en51cxI8^-Si zk*OXUWf9|0wA%Z6ClJePoa51A@1gB^Rmy1Szi8{r#kh);G>UUO-v|wx_T6FTIDNk!@e0jg*^sKiCzBeZpWp- zh){4VsO+}va}u}=n9lBn zvdC(CzGywX(wfd2S!ESt!1&m+va!&X58DYza49*B=aVW8dE!4n_D+7fj>7p~P_2FSfOz~o&Sie$ors(d-|>$ZND z`f*Mm*K6sB@O}+c8DVK_xpCTdE7enhADBEbb2(U(Z2nH(RydsUzEo}i&4Glc^}heH z%2n5afCmC3K{0$`Gl!0jl%X$#L%&BU_yH^G8-4NuyN8cW>?3)Zq%wcwUdMXDAwlJY z)8hC{I$or!*VEv;+++8(`w`ei^Ivexnz?W7^kZvKxp~XzfUt+pOw6Fst5!>X26iXE zB?nzJzA%mRwAgO9p!~{>!ScDM{(WLGosIUIRs0Nk;Cdq0B7V(CYyK?FFtGCsbSv(9O!`r)~LYI1q;OBSf%?m66{qK~JV z>C>*&2&uSw$v2e%8}cSy2GyA8!n;E7M6G)-K${STM~w~JvG(hIpE z3}oaBT#GG{fkAUGq{H4?Nz8|dS-hAQpZqsf?N0eIr2K)y-)Gx4eTX%e%FRF2w!JFo z)e!F%#=4O8kM3F&AI8#O76OJN;%494Hp9%`eC@UJQ?Bn36<0dma11k<52hqLyDE3Q zK0MN!o*pX|%h~SKjzkV~%MJdr`k2FJuCjVW!iS~5Li-*mk>6c+<+WGzoF<1V*ko=i z5S4M%Ll|DWmP6Dszwr6-ON>lMj}!fQZ5B4&JRH8++d zlESblwq@0DYx(iXIw=G-3z?fe^u+_mJg_)B(3ch?x4Gto+RwH$J6W{9pSg-8t3SH5 zx9Eu`zTN#v+wR$VLnte4Jm$Ws)Z}q$<7NNx1lX0}wnfyXC8Z{$rQFTl51Mm6{xeUQ zp?bDqP#SVI$iq2BHwLJl-N@XjWt6NE1X@0w-nZ77Kal)(opzc`Y3J7_%s82;WKQAZ zPsmDce^<*Oeb*i~rY)}0GU%4{Y~uJd$PlXLt-~b)F)HyETUml02YI)iYSdyc%K&nB zbRC$-L9pU;4mzK%%q~z%qb#r_H|zEk@^EHeTH9XG?$7V(0SsB$Yu+#H?Ya0r9Bb=b zZ;Pk2io=dzFV0WySCD(HDcA`q0$MeXb-pq*Nt-VbK;=)a;1^FV^&ew+N2c>Ct?wZW zCuWt6)r00kgHM4we&>9p0r!=Yr%oY9q4$pE>dq1dH-@34;~>U!L7qeD~LT01&;>&;UA2v}-9NUt)E(!E&t0!LeGWNp`Q5%^^*Q7zPi*db0r3G8_Rkg0b;or7Tw#s4 z0{pxEsXgc5{`kl5$6yH=;I`QjCI=Ys^ZTvL6K1PNpU%Cr`^-hNpF3*JpSN+ku$wy) zgqinQ$~hl*V8wFfJ<|1@(9X@7t0X(C_#eqk$jgzRO@|)ZTVUal+bJzU@1+OFJEc?T zFwp)u+jg5Ub0FJnb#)y6a774xxOfDfwlbFrfIC?2yI_S{ttm0#+bV2qn({4u_m6_{G zwkM{|W3!=ZXhzjcodW(!Qk&dSi|;J>(hpjyIdNV7Vfr{};N9X4`sW-k#Iou&GspMY zktx@bX8m*NUOvoc60g|-#>eM*{;erval>l|&P>qmqPcH(xf!HCf;F|BH*Y0Am0@n6 zb>+p9#;m-NATGCCwfr`??d3CQoHdR+?DnE1*JNpt+`g?5f^O)tVPXNNUsy!}PnI^l z@9>*v&Kx{h5TJ=((`)o-Zol5^gM)Ey_NT2_O?rk9>$5Y8h7q3y1_%t$c|I58a&0i&A7wtrlbl*a^&Ck+x@YL zbG($if6D;#`gJBAIxF~<6aB|p=A{Aj)3lU;a0${jUI}WRLAy$iRQ~y;Uwo5bXF=uT zk0{BSCTkB<b7paZmP^r|5Ph( zMZXUuL-XK&!PB5S)!l<|sAfUi?Mk;Dc$=a9jPgnBton8kGnq9Sinh3%Cl_k77spTU zPGJGp%-2yA^lG85<7GOkot*W972w?e72NJ_d8adQ=BG&IzCmLN1eZSr+~Ny_-VOs> zpU<{Ia!*&o&5wo!G2#S9S=*LtaaCs5DGo!5BXB{O!XG(~;5P=h*H!)30Rg0P_Y}Lw zq))JJ~hlDu;zvIEVzFO(%TAmP4Iw7T8g31!(>ryy9Hw9q^xS*jdB_8^WuAO}L z!o2YF0Zu-q$-~CQWq)d8gQxXhXE=bevGj+wzI~9o#E&IgPV3ao>*=ADX;yE ze|Ck?;c5BATsOOJRa*2YY>)3{>CxTU*C2Rbtlf_C;#ZjAFPyNhI{ zL#yVGPJivoR{9irK#PgpLhsKRmZONDbnb0wPuY_F&kH6~pQ@_W9xqP4{R46XG3g5! zt{E5#bow*lCvZckw6%WrbbtB8rsq(XHQm5hY^{%AvXG#wnEl(^DTbE*H8+QYdd${m zfi6QjlbI{&=IwM0PzUph8VH@Sw9sNw8wnC#5?l zeI-A5?G(xY&N(R&@6J3@(cV7L9=Rx7(RqT(SU=uA8R7?RUyOMAW$eut1_%4=(U~vz z)UL2$t$3a;xU4mvu?@o4&cLd~;=7KM>Rtn>zE|t{h;*95_A&^6svAzA&xdG25^PO%8IIb2J%tolU0` z_S!vp9{a?Y2oj!NCS0i&28_9_zXWgdwAVF6*hq>;bbdYg*v#2)yR!dub@dc-eYK*> zdkLF7{~29W zAMvicBkY&-hIQ=*-c!|h>y+s)xd!fl_3yPLA2IDUH~6WKX3bPj#|^%Ap^B9Hv;Rou zl)dB9^A7|5h~y*9@_(UnkK~b6jmnvCG>Fh5Y$p(XY{6*I-qVzxw60x8i}U)@cZEU= zt1!8o>?OFfHuZ6fehOnE?8bDT5Q&d7IhANVdX{oakXs4(n^r9+6u)A^oc zs}F628=KvOoN9|}u;5-#7nvvfMexL7fTO)@a%lV1QV9bKH%{9Bv+?qgua?{c4%d@+ z4^^sypl=Q}RG*vRY!;U`Mrj(KC2S(<_{}*!j=5;Po7UO7*h;z`L)LVPt%1`e3sm@N zVF@_WTRLokFtsC3`kCijU2@Poz@4P0UY4{wNa!v|tgD*t@&B&A%g_LLkF@UW4;Kmd z>MuEM@$&s($nr(tM-TkLS--!3LjAA%f?H+RI)jsopKUa4E)a&RL*b*Ynw4&w2Z~Eg zF~Wo<9`_h^X6-crnBKJRF`j`Xleiu~t$}?48(J?+5g)^Vp9F61VeSMe&~E>ul+a*v zm{-s#$tYc)#5RGQ|6ksjvrHT_ZTMu7E8+c4;4Ovhk~s#MC;?zT z_{QVd^v=?xc#1}0E}nUm)x!+;_}fDYALKsC6G)7uN#^~$+~F1flk;@iq_qE>$L>rC z7_q%=x~^aHBrV1=Cv)N5j&_Y-ZWM<30+AWX9S%g0)2(3eXqkVu>6Rg``PPVVR*&(q1TWLhN-$dEBGc^@=|yvtE|mymB_%t?>HWs(nW`^QZquqx4n-j#@zQL?aO4EBlp& zO-k*(g?C5kF9rVM<Fp+VIv#VG@un5(DK ztS5$z1bGvhonsvQyE_zFaTLjKz}isC167wT{^WE)1n-r(1!TCS9^TBZw z|83&IGKL={T0aJg63Q>=g~rT=T*Fs zbXh8L7YZ}sa&ZQD`h4Xc-i(+;*Ch8pgNg;hIlqoZ;pJO9>jl}Xtt0`V$^5NZ7!~u$ zi;bJV+NQ26+s7?Kpuov}$ZYa2IiRKhdLXM0FS=(VGt)$U=kn6^?b+Uq$F&Dg)~nH) zi^)AtuvD`T2mQJ>K*%!W1 z%;|QC-m6ODC+4629ZgcKZEU_7!jw!{TM*ljWY=8sic@Ffp`&5vb~$+W<0#KJ*pId*^q@LifF` zdbC$PMhawAj- zx*nay!MNgkLBDhd=e;#N#sn9?HQetDE)N!H{4>3QnnEmLDNgm{bsE&$X#Ku`_kE6^ zpu)Gl`(Onj_^aI~z0ZupN5$l5Yz^a`#6p2?98g;$to`P?Ld9B_S{%>ZX zIagCyebfYu{F}(?@v6|H`mnCdiKX{9qWQEG-T9Rg6ySm@oGp3XuCVS}EgtJ*k3@Jy zA40duvAIW!zvFiG2*t{69CCLrNVaW}cZKYm?Ed7c7dO(YY?l|4d@F|xLpN|EVO`g} zCet?x$nKbPZsbor{;sH#({_Od%3Ak}tAexR>y!9IT5WklUsAd5@*gTSNYjnR$`?ht{F;01rjFIj^9 ze^Z9(DGWXy>+pQ<<-l#iM{|yZ>^E;fmFL|wOzH{_(TVVDYZJ%@S+NN^sG)-oBOGWN zS{G^jBYeM*?#%G9`T1yD;u&v~Rj&jWOs4}GuLd@M)bMSR?r%=H%%w;;BrXims57ra zpJULV%?%SMJR3>ePuehhC&~jdZwhPV=BJwpg!8t2El|P>YcWds9Xkp=n@bF&lDBBG z>DSgq7k*iSaH;fJpe?E_wRxb29};660Y+OUSAv+aR_BZr0`1O3H7l8)Q!?aV>9#wn5?XV#_HAZMhQ(D``55~0oqn0%e69F381}&TV*~e9DXrnWTRJO`*1>~ZMw^^e~n-#in z87+}BY_y%4VJ5f^DW^Ss8jJeMYx(`Fm*!EiD4et2xXP~FKM^5}sqp5@(P`HmS!iqE zjUbFJL7T}ei_#KT$yPMw?ehof4!Zytjj(jp;Ee?j$5c9$fbf~a0mh&YQAb*bff5`s>egk0$kngSl$b%CB z@~Hs%4MTuD7y^)A0LWYZhkQ>3Kt31>kWU53_f!DngP{QVRDgVU1wcMH3m~5gkngDg z$OmTuArAP>}FH9R=WpnVPm zfJby!0OW(S{zd+r=l>!P0>}eRMLP!50OUacdEhWi1OWfuvIzpn1OI&n3C{Yz$+x`% z$d9H2^@&OtE`EwqCJQyG!r~#1wv-ZEqzkbV7vrD`VqK$pq^m-19{3|hz zuFNZPCUIqRt;2a{%j!8EvU|YV*MRl{2ak@uz0T@5wK=a|(m=Wan^B9O z;rmkQ2W}np>Uqah-;6I*zgi>N0UVn81yCUMvBv+T0K-goY9MHOTovec#@Phz^xYGUn0onqngRoAOK!5i1kM6p=A+aC z4R4bg4d9f{KTYk9ZN^X${P_aaf!*kO&5QdSWmkeV@(1eOsDTqFB_wzWXTV8f5jdT# zD#10$8#Rdk0L*T(q&=F0475>*)Zf#;E%Q3;Nc|bg0NRw{3!koflJ`C|!-0;R&+$d$ zi}5Ha^hntQJ_Rl)7|I|Js50M{)MwD-(@V<-(+yUh;JPkc>2-4dlgIOB6aQj;2*%-4CYss%nP~Q+wZ8J1 z(R*Vd7SGU0lT46)z=ZN!V*z^i;6$X+h8`rpevC}LRW|?SdP=ZJ{d?XOl6IN>#4aK3 zew*$wUQA-EG*UK!jJsdG=`F8GVuutm?CAVa|FIr#+r5*McD|bQ8n?OT0?*?s#Ib8) zHj$uiQ&3;U1YBY`q6&#OxSpT09DVL|Wky%+9`*L2WH;5YLY0~5<|vJJRZrgcj32C3 zP@$!FSrE8vUZvRGP8PN2=2Q zYrLl4=ZL6z9cwyv%=zhMR#p6S%>!bp>7idq92@)L{hb#)fo_cv3X=^^GBW)XeVtq#ZUpIPyUpa0;RSRSp-`~JXhDzd|?=iy?wgk|*CxU&ogVOSTLiwdlZ$k8-si0R_Dx!P}o zOqd~f5xsBFvDRV&)fe}obsq@!mZ?+a&i(XQB6yu1v38g(2}RE=w{_n>TRqOM67FFo zE4J{L2<%V5@_I@a7LhkH=Y4RGsQ*NXSL(9}aaEgpT)Z7!80QRyf zEK5Hy<44x!-H~QPlSeP9|Mjgu}j@oh0B0X+B_|x9w ze9srJx%BL(cruIReeTl&S1j0eB329-K0-db8C~UKW8OP8a9e!MtMu5Oa=-EuJ>h~cZ(Gz< zbVJ%*s;Kpa*U*?~@5kE~+6u+pki%)_*y@JfBWk9t!3d>N-p`jxQR+PWgz{k(VOHIz z@BCGQKIm4AoXd7cbkz#cyboB4nT+w0?ec)T7n+cHdAICf1j*`b&kKl0#6bRKer1-a z!U)UrjHEy@kYAHe8Cb8z>LgJtdkExP<=4)vhqgL@In^cx^63gIyVFJ4o`z|U?1H?} ze%6=bB)Sh+1gI}zIWig8D_RcCv>haJt&pGz9( zxc@TWOQ0K?D^zD7x*kajq3?Nf$Ys#opuBH4X2O$q(!O(Y%C$%sU^epe=gf4~nhCAj zL)jYT`fw>)Td_}Sv{ULavM2|n&NmwC$~g(z#9`Sg<#cEVu%^O~y`rqxMppFg%s8-a z^&BPgE9G}Ien_J&h0A1U_*^OFBt-euCW`gdIqLhz7E9L*Y=k>Vy11XEpAfO~Scl@% z6Tatsc5+#^8K?vQA4)HuwzlCtcx!JhRBU{-%JHmvC#2~a#NvKe6rUi@qDnSQ@vz*F z*LL+UAsE(20%1C(PgL81Y2ca#4iR}1SG?#3zWVU47QU7DH?Vy?itgGy+Bw;}MA{e6 zfIoIUbxX8qU_|{XlSm&dh&I}b-xoBT%HKi|@;=)fyZZ#fXM5ZWL00scqCJ}LAc9?i zYrj#f0+!)-DnU=$sHc|5zd7U|uX+j82bFR1ucX{M?iZjN1nOAf>%O7r%H+>}f8&R|it!Sv4@Xw;=aPL5*l+G?5bE07)c%&jw9-W#3uk3WC!^+CAcyvFl*TmOY(Rn*S5H79 za$(h`sTJ3uBd?VPGG=Ch-RLYpI~$nddi%9JA1`doulRS>BiI?6b{mzvBigAyNvF2> z%fl(SN}pqwLsg*;AMB7vd&EH=jy9{Q)!|!4BHCVhqDw7!e_mg_dm2pjb83O6X=plJ z>1Ajh!mzTZ=si6>E3!dS&SCebob3D4>#^ICe8$#uvFGwjWa2#xs^kUMg#CckWQ;!Z zbLDDG@ppYJ*KXh-zm)o?RR2#Y|BOB3(rl{(D1Nimf&Kfr`0MO6*`)*i$gijwQ^dR-T{)$C(dXVC-tcS&d9&=9 z>lpUIDQWJnMr)%}NB$M;GdRC#$IBK;9!EZw>GdU^yjSK}PcqeSmuKjA#=69jLtgD9ny)rI zu;YcmeF3lZz&*H*Z;Gvn>euybsmgX|8*rEXo#|g3cl)Dya&@nMZuXRKM)>;+1Z}Mr zT(Zhpf;VD5H{u6y+ZZY=B$*lwGM}%a=Jy#j;ku%>7N}sY=_)g z)fJok8HmqyjmIr#QSeuc7gNtbMz% z0T0I%8@b(IUhy=6a+)A8rErP$rF{%P9Y5{bu)|qcT;7yh{BwJ4;+GxKg7t(Oqz6p` zdMo${Esp@M_}?~7j=dQE9G&3MORnoaYqS-ro@%i)*@ z9qnLut>5No#YPGK?1@15{D@nhS(8O4DSysXklp3&&|=x&yg5^C z3M0+P2JY_g{uN#rX`9T5Lq0Hw{*wdNS{4}ni2;pH>=SPX&$OHL+WiyWF@N*eHnh(2LiXu(APdrLZQGtLO zH`~yQs~nu$jSI=m<$Z8^BZ~Cjupxtg^ZJ=~`iqag>~F)LbK9!pp!*$9h!d^ttL!?( zrn6>(;u1z`tsT0;%8dnb-v=k55kUNqk}t6(J2ow=x$)G-eY>4xlE}lRSARcX^+~By z6Bl=GiqziT(fAG5 z9X}pxw@}&vy*4YkmHMjXkF}%phgM>3UzwS0+L8oUv;&&=yMK5|wng;UB4)D40^9Rz z^3Nrk?8>GD>5~Jy_g|vDq?+tr(~)<#MY$ij)K;qmhBrii?T}VGMoihJ*|8qj(i{nW zz8;CuK-ZGK`p~J6Ya@OAD}BZ%6u*gC&xX9~!K?uOB84+d`7qw!5+6QfWk%@p*~*OM zm0*?`d6)2?QieaJ$%w^VrSp`QlL7Iu)fkHIT`QRK$*aP8+>dNhmW1spvroD9SiAfL z^B#5iNkj|D#NATd?In&3Fz+X3mxA~A;Avs|(^RE1epTVkma`Rqei|y74kp!H5Fdol zU#DqLu%u>aYX^d6j@;R9W>$YTjmlVpF*4OFzY(?1D$d)}5$=}X+PMV+iX{zz>L-96^`XYMz#3$ZPJ$-@OD~B~YkU4M7 zB1etQzn#ycO01u%dU>HkRT}S%v!x?f+>;ZWfz9~-YIz$xR`bd^kC6R+I>OX@`f!m*B`gTV9PEtP*>5#h# zUh7xy79bGEJ0z^%)vBTxqil*YollW4H7aP+uzcp3C=e0^m zoi*94q;dgy?&L7sba_G9n!&l;T<-V5=MYP8^PamJ13UIK8RI}zw+$&fduU1=d1-yf zFwss8haFL5)qqdpe(1;EI_feG$6{e_Njyv+6P}W$DSZ-A%Fw=z9q_;x{~K8-cjn1+ zG3+hF@!sjsHOaMa-4?k#E*k^(0J{cU;FQ5Mn=#g zB9&gIF#3dw+@?!hq6$J)`-G-$pBz1Lzuj#LyrZvQTRA-pKFE9X@MNTduQHN?&Cib@ zDat%kh;VI{ei-&Xi_9-zEf+f(?1jCdJ?Na zH&d9(80;NTvSrf>gVD( zIIY#0SD0zQ3)UDEkarS!H~)A5enC=|FDoy0cziQlR6lgRFse6}C=CX2+n-$|mv=3u z@0{z6X|IFj0+FRKHd|Ue6HO>yqRFsND5HD=)F+Ip$LqGUlD$CQIC9JDJ@gTxbz_$@ zX|Zqc6O~f%OP8My9Y5Y`jklf+abAz=#}Ugs0r5Tkt(n(0^_71AFSA40usdxl-|eaT z&bAy!oWK{Q#7p*mk`$!1j7kY~K`*I<-0?1Zn;DlLi+LH034TzL?ID)bX2Gw`G|G!i z&In2uG2G`!&*+Z9J!vi+>QteVMT9-k5Q!%d-J)PL`^ZuL7^G7kJ=LX3XxW_L628d; zSxPg`vSX}`cdp9@O{{tuj=}DqDZ0fP?nHqqh9@l4<%Hdt0#PsAmkf8>DM>Y%H3%tu zQ>obOLGv$ua)uwz%U_TGwK8%6K03a}?$X`x zP%n>^AR`EF8ayiqb1Tw&pmXbRn{%fk9gEq0%S|qC5p+MLqn@M3v4rgY>|C% zRBk0bC`xyX*TswOb}&9lTSnx$i@(&8OvUq`98EU}$`58ie$mnCbj}>i`Wr{A$*D>g zeoxlTc*3W>z+0$wP%@oxr&)JT$;`9gJicmOm80`oGM(7-?T;$sAF4+4GSH4_;i5xg z*0-IYx4HIGda6EWql`z(8xH7%N1OXwKHOjYf?A6^pyB7=3dRJ3hQJ7I@w?Iat<+D_ zOlx1SQ(~pCxE&&`1`;$G_~+zP*FvA=`QcX&q5r0BkK2F^OkRC!cekC8DTEvB6gT4R9cqTCpb7d)tEFeF~1JvE#2l z*P%QPV(a!16cQTf1Cc*?Id$hrNSm>?c`&5TzRbFAl7;$;_@|YgTzJA2<;w;cmN{FB zWv6F8hXe*Q^zK^rTBm0&7Zk8nZ0+9U@3+8b4ZO%5Gb9P1RgM%x-ygbGs;Pp~JBG?C z6y<~L7}Af=poB_ub=;U;9KWUY@DBv4_rIal_M@vi7U8O;*9ykkBw9M&ElMii-RwX6 zwCCNlBbWtVYF(#VNSaB8ftlo@vjY>T9c^4afDNOl4`eRw!9?X%_dOB_xcl;7t}Dwzjr8QC(N1da1My{sWqP z5?N<48M|B?F%C|tee5i$0!pn zLJ?qyUYXH6|I3cVSOLe$mxBThG8^H1Dh-+@kBINLOp1XpO|sM!>=wln@g4OnPyKp> zTP+`b*E6&hpvGo*%qIxp*G^TuXc16&uNoKv|F`KV5kHt!o^ zokZke7o**1fN|t=8gh#>yR1~<+KmX6LhrvrJvJ=7&)kD)LW94Er6Me+f;Se-9$y7#E_!PTs;Vc^xzCVE=Vq)kDA&`ttq3N zNpu!t$;>VwanILUONoI_XrMF7F5zj0$#PVMy1BmYnxlBL zT{@T5G@CXmOTNl3hgFQhKACY#Gz5Q9ps9pWd^pTumTWiFmA~$(T5@A*X5(Op`aI5w zrtiJFUF4Z?Nw<*!f7+YGmwXRva7OqXI(zFHRQVXJ6RbPBtQIH)8_b1?Q z_>rT{E$@UARN=fytk zqlI>Jovh+qlu11xZ*@Q5+4IN^$T7I0z7*(@NcgkD5fmg^y7KPE`omN!W zBGk%55oBm;{Z@GyxH@A`!b6Mz^}Xga)5m8NDIpQ?0?+4>bkpLLL8pg;~LrSSj;-Q zXZPrqKEW@u`yiwEA)Ji~@*JzPVrg+PCxck_$xO;o8KF1J3%T1e#`saA2UzCPbA zm1Ri>8TMlvT=(?XwMF|JMD}k=hq4y^=`tb01v-pR&PCybbCQ{Pk&fc4SO(P-3z@LY zXrVk^dC3FG+wrW8%AFj9f*5F98osqp>Lfc8(0p2Y;y59*uC-g0!abBMtsk4)SRxLa z4;LNoymRbyz0<0ABfdv;P{*-Nl-@9KnJBFw%vr-tSAt2mGlbI}@+&;1Nct61} z?ev4LCn!^g?;cS%6hF5G{m^9wb&R&Jt{HQx=S#7atR(^O!Wbh48?Gh>2w!uP$9!db z(cHr~%Q?UpM}NKg=E|TodIUJq)#4wRF%5-tE}utNwW-T;x*y zS--UlyE^V(j;)~{?$pmY50TeaP+Kq09AGeg|bBZ zSTR2&f^w;39a)qoMON8=7KDBe$+C&vbR(@nbUnKl0^MR(RkR3KP>NTuEx{GK-8Yv?ea9r&0`hj3Ht3z2p)kBlnf5as1aw4*YdWi z2o|3esnsL8zTqNJF7-8ui^@DN@tO(C@C)EF2baKo{(i|fdjAkjhv{v`%=!D9x_yRO z%<64Fx_>@5Y3TRTd~<2N{wrI)l(@6Sn*g)-`+F9Cn?XkOEZL5)2xX7EicI{MSsJPl zVWv2c+&NQ!As;(a;p};f(VK5QarGTL-*BX~-^-4+EK4?FL70`L z(~4M7jvT-db* z^%}7s+k%J6I1SxjpNUTzJ`1i&5@7~E9;eATpKNp)m2+&7)~B-gwQQ2&lkL_ai)UBKmce3nG=)x9fys^T zxBoPKx$f8(yZYE#!Gq?Zr$Jy^Jor}Vfh5raFeL{K4g~bU`)xxsLjOE`rPcfI9n0Y1 z6`$O`3aI$uM6E(y0u66a7(-?pKgRl@UJhhN!V)r}c#G`DBCxNi_?*H^9$;V2JpWW| zlLssGSVhdB4=seHTy%UG>JL#i-9VQVr&WiAY?c@uaUu9BH1KMYOT? z>McP&!Fw|mqSylnj_fjLT|PW(U$m@;K^4%zLddY-b0=AKRP#Tb@;qAf6a|HkYt=$_ z4*F_J7^!N*Y)0!c%uG6JxF7A+loWQMBl(N&PABm-e4bKiN|`z~=j91v+a>Tr zWhG|YJtv1MYRfh7CJ%*CGOo%Qwr~fduHp41O=KS*(>||HrKWF}wORX+(dp`3tD#<5 zUy{?aEr_?I;>u=%53&E={v(C9qu(BOMQ*%`P{=m*T=k^>NZyf%J$gIHB{Kt!_l6Z+%2VaUx4Fb6z1i32CV`Qjy3TExL zMi>KyKM!m1$^e&Bm&ar%8aOcjUR*_tkL$ZZ%FGvOtcX-#qH{5mcMIb$iTxjrh%<<7 z?N~|lQA^o|y56@aPz$h1)#=<6WeD+AUvrk(X6Ms>@^QhSx5qE~WovdsC$elwKOvxOg~j{XwgEUE`7{gX|0A z3k$vEyblhsBzBn_In?Z&9m%o(mAN7Q9lHIJ%jGP4*j*$Dgl?;WjQE4&Lb-|m6S@h5 zg*Bk+VT@!zAQ&Rdtz!`06g9eqAzRn3{3UAm?rM60h|rpKq%KAE{sAt&w#bixDU}-5 z>GTW=dwiAqKC+!6+%Ub^d>;0+RqR|&(nu&FVK1Acp|~_+XFF9%!H1-BsDY4sESZ=9 z``~vT9W9mPY3bB%m$ayc4lE;|&mq)fBvWSLWqC5A=!^P;;O|)GRUo%eR!pvpALYAg zyFb}tz6`tag3gnzE4!Cc{8&Qgl_-8B|=J=Ku)*If+3!9La?Ryy4e?or5=kXv+Y2Zh=*FYCG3v0ij zKbQ2z;S#JRMcNA^;Z{nBL9rj`a*~?nRr)!2G)$JY@e=RAKo$4}2FXkgn<5;(CT~&u zTsP%(c^ye14ikdM35IPb?ng5m1!lL2vQEnU$EeWSc*Op4Q8_Ltzgj|`M546S2)CPo zQZZ_9&x3=hDIl+&AsZDXsN&2&&k5;8sb{%pCB-}LgUWNLjp8lTN7*=jKoKb9!<(|4 z?2b6i9mqhPNIM@s${?PI0v&JX=O4=iQDb!L1SPY}6JqF@;*<`RcjZDXHB*N_my~+P zq=6L?x6w>i%G7Q?q1y4ov@B(Gw8qgEI+GMTlgn5el^6ck3@Ynx6aedza$EwfdrRFo@BA!*p zF&GtgI$-cqpPZ%VensaKkWl$w0j1H1A4BY6Ax}v8(7(mU3vP$Xh-dXxl6jwy^1y$k zg|{{OOWS^P?K(~?R-V6g{osSCwy)HEkdgg0+(Jk7+Le%SDlTdl^ctVcD4a=p^kRE! zPvi46r~k3xkBD!*pDrWbqeDf**Y0({0N=$L=x)B!cQqj9(mFh4VP5AOmbAC5h0XYZ9AiTqVVnYBg8&69o&OM6jYpahcI#t+=; z1y!bN$EI;>{W!ylVtigz`E8$Z=DPHrQ*JL4^l(C{ zdF`o%jNTo1KE$>Z$&huN);jj#<=0ZFf8M?*Ej96S<#OHicrw{6N3CH(9AS)(Qnf~s zWw&OB*v*?khC5rb(p=rO?3QPcsfB*IvOyy@ep`P=H2)dU=;CRi8u2q+%<)w3eO+ZN z|M&=qC8a7E^zfN|i%3N5WiC;yRmRGXtgE9NR`tShUtVU7KmN>%ZM>X0V6F`=zTT)# zeM7dsN<)eojt3(Q60+M%ah=wpk9{cVYdE<)cvv%}%Bddisd8zKCho9o|g(0g7NC9qYL)O*Ohy2H3jl!4^^SCcl95TqzbQ!=|K<`BBd z=2JgerC4a&LKv#StAdv;f!0yCUiKSwq2E_ z(q=<6ilpv&IL;10SoG5@ip7V^Jq_0rF5}4FWgbd_D#@-^WU}zXeOV2^d~7mRZrq-8 zKj=t;lWJ|5?ZuV4SowkXKI01_(-JIa-=klxQ`t?NvZkZD4A!zOhk@|D&b92z#h~00 zWn{T2F2b9Z)OEJ9}b=|JyvCJlTO^`ag zIzA#V1%l9Co1%Vu2BXg_w#!xJ-) zrKP65%Bo$QFYR|DDAyqhueQIrq}`$juyj4KUKP5Dwnx2jx|D&>jIx=#`?2))I2pgV zksyB0;34Z@fBt zguA-|@%E z-7!v2e+0g&kF0*!9&7dZ1JuLSVQON2RWQ!9S~|`48-^(a0&^dyHBK2_2DRlBQY~5d zjOZDUs|nY0k0D!2iX<0s{WjE2KJZc^>MKkI#7k^%-&4u4zvlAWlzZAF@wrY3&|LVr zZ8Nw_3vk%(!xpk`lGhl=4gud?2lMi(deH*&%Lxk`gGcV>GMUK-OQ2?8ls9hSG{Raj z!B5zs%vdYksLaW4*UFJNGf(dBA|X?^9sGDmj%vQR(U&KSLULBEX^^G-vReZYZOM6> zI=Ar#zmV!JlgG%<@+PiNwQB0{H*~q;eKbpJ&fpZ<-mnYV2(YeoKIK&NxJ3T3Ut3z| zIHr7oj-FWH&XV*or?#~*LS6hOOXR)tt@Ul)qEA=sOYGL zxvS#@oYNLDRU$L_kYAf=2iAdz4|xF?Y~xYdq~l!+iSbq!OlfTnEpz0asl*=23WJsD zL_726TN`hHxx(0k3!61CBBE3#LwpQS@s=&Uw$40hOoq`i4Kez=5$Qu7ZHcrZ-VtS4 z6mF5SBKqFR*>1nW>2fbyc9>==6j2BDlM2zV^;jx&M!Il5c5GGRK@`Smz=fErjc!3M zlGz0@$50@)t)B#9TN4{fg3KLNq7T2MDgXJ>mUY7(5h!&MUC*wzG?o_jiZ0^2OvQWPHZMT3-S&(_e z=6QxO3VM^cRbS3doZoCGl4PbQ^=&GR|7Y&RyFsjL9gW+8SzJ|=owMkUr^r|y%NNjD z4q?AB^vSfUB9Fr(oK31sP715XNw1C^=!!*0{P&JZekAm(U;Pi}W}_G;sT_jgxb z7U(-g8X~71GGX~d!rky#)|Dv|1<$;RU)|15Vx>^A!YGHrF8DTGREDB-FS!gbH;$9; z^5YMU=%?f6x?}e?J-;OxE#k9(bo*P|cj=0NLRT=3TStO+eaKYodu6ke!(5$&1lgdq z7_Z&Wf=EO)iDZ5kEI9mgtw&B9+2%HFvE)#ayJu{n8LK zj=b>m9&bYJ9*ji6z&yy^@6*A3Ygbp6>q>r~x>d@OdwvO`YwT?!)LweFdJJCQ>yiua z_{+_=+j7OGWuuh^x>8RbX|VAVH)L_R~!eic#A&ddydnzIggeyyYVCNQM2)Iw4u@?PAL{7an%cUy}B z&W!A0IYm*60=ACK$sq5p&R+dU@#>H6{OvlGU<+Q=4Cy#slFNsmVOtLrKUYCL`Z886j*7{6 z7!XA9Do!bAMzFNUOaIRHk-5`W7PNMf7`+pngMY7k#AGWkb^Pphsq&0V{!L{9KwW4b>~K|Kz(G8g~d7grTMgqlfcwbnV5W8a-3 zNDL#g@m_smHk#&(N(nK+&ugp+fs$A7v1clnD6e?%Dc}rNLiX}BvS08fLAL%xLO=e3 zj+w@tc_bb{9fteR!w^ej95GLwz|MGKOgdFN4f#Z&5h2x8CDp^HT9;{LeAv|#BF6(> zZ8E11LgkOY=-w^AI!^u0blx1Cm57g!55>euq;rhukw5kGLHwV=PIU<8&53OzwI|DEk zi_6)uv(HTNnW^58h(5KMKy{|{@+fCiu*WR6IK7GFt=-cfj$6_1Gvkz>QDk-w)@5`q?3T|$^mUH;L|Yey zs5zbYFFHOrQ~jzV0a3Jyx_q3=@By*ZvleEyhJ{ZoWHC?s-43 zy$;TBG5|83Svi)mx3B#SPZ3Nh3~VP6W%FdT__&s#=;~d2Uv0RaHA|%9p#eEE63WOB zV{hBg-=OJ#^1JD*_MBGg+&Xv|W*24vyaiAewDQZC-r1+Iv4B{S(d(Ty z%-&kgg}K~`UAp^oD-ahyA9jWM67cz{3L-jaR05;H7r_7ixfzHfx%%7gHm3{i6mQeZ z*u}f;IqafV%#tXF`rD~th|z;>!HCZiPz+H{T*diB}v zNIb8o>^h=3e!nS{zq%|Yx#(NaI97YXr|m+|tzLZ4?tBL)u_50ykRfSFkRJ>ax&x_Ak{A)$bUL}Q-A^F3 z%lMtknW>9pMx0CR?^``iCmipeV#8Gr?lLg4qhbAq6?#PfcBlDs^M-N3)SrFPj_t=2 z@CiAM6SP`$&)xshp zQw+CKWO$PbF~rA843M@U$mPND_!j*xgOnK?^(DXu@pIDUJC@m|wW|nw;0Q^VctKJ} z^Ty)Zq$;5{C;#kZ&?`Rv-!GE-`G7st{Mp0!Gd>MDP2;0jOD2d9 zwEdZZ;XjMv(Bvl^Rji~dakmXti?63|`&~aph?@R?b8+0b-39ARx2iB~(#-v;2yDwt z$7(}ty3F=!M+8Wc>&)wSxW`6;<^P0A|D7q#L2{$7S^#-ntk#m`1j8BYt5emrGzaAM zb3k5e{YPFq0P=bWveX(g!kGm8NF?8x0`l4xkk_Gbv=Z=iw*PXrvLKTw@Y3pfz+GDc z?%EX-RZ)U4(bu(r0rJ`mkk@Y@s4Q#bKk|Cpa_(Q_3pgyUK) zAg`%whGOJUfV?jKm%P4u{eQ}9(Goyj2LtkYJs}pOQ>{w;Ob?LPMS#5a0p#^tG$5}Z z{h#vsi)J2bIbBn$_+Rq+7Z>p#cb%t=&v=moxNAYcU5^^Q+ed^W0eKApGZAgr;XE5yxJ<+?>? zQVyF4zgY45GNML}=&`m1bm=JL8w#}L!P`Q*xs=+%j5>_+$0EQYb-0R$@OT}GEj~_N3}8&Z$vATSV7TI16RqgA8FHM@{@GPJ zfUVX|;dVIsPTU%y&h{M1ZYttTOK2J&fR}1IeA&fl2x{6KKe`+VhU<}xCofQ06BlX4YpQVG3|5Shc-)eeMr-qd#5dDZK zK8h}-CY33;rV2u^w>(o*QtVedo9!0`_z%SY2#`f%St~Q$d>%HsHP_q(zc+xtW5V*Z zGY=RZWFlpaJF#~F+(%O2|ElY&EN2H{sh7ReRBOxIr(h?&m z-QC@d(y4SeLk%!@{Jqb8@AKaK+&|8I&S%$Id+#%ApYK}VwRc@=0|gpW@%R3WlGTZz zlG?fu@!z9W3Vo-MVS4?M5{5|i>o%FE7Z=@N7!tHD>uXv3_+v(CXUF^h@@8&-`1llYY#0w2yB9$Tul3&YJ`gvkgYh>Y7O{nI(3Wh|27Rev>=(OxuOtyR;kMcv%JuEhHzeN(G zrqQ~J{UUso^tl7af>=RS+&Nf@o>E|3cl%UhwB zd?N+Bn8tMKfmRxlMR{~u$NS@EZDq5(o8VF4QTp!lKzyUiHVza)5n7f42n=mqLu5@7=_f=`6Qj-x!ui+Z_b94 z&XdEkJ5VS2h-R$LA{E}JpRvgfvd0Ah)tO6-Y_vAo%Ar&rwN^ZYNofns=?b`n)I)0W zGOGSa70Ka$el0ZcfxkH8T6fm|Gb)1#Ue%vN&U{6Va0-st)+RjHRXO9&1HIg-%PnP+ z=t?I;?(g|p?-JfDm!F#x5zpPU_)w2X3HCBs_%tr^=`j&pS&lFa3IfpR#?0u@*%6!Zwq)NxFM`QaS%a~HeF+oUcY4eu z4g$tgo?tG)G`yOW+WBnymAWM#FNk^!1$z-<@;?(;dxp}bdJ(iO)k{N1Oy=&>XM7Rl zt?lx3Gwh8Me(^Z$Yb_Nh#tgB0xR7v?Cj;RKz!PVLDl6?aG-!kFyXmPJu}&4T@e zQO~J0Hm%}=Ju*`194;sjN(4L9 zx)$UL(TJn!)KpTvS?WS6v96*;J#JoW17s(MfWsj5Ul>6{iMSRN&^+H45fyX%NWcA* zC1zMv22xQ5=Q-u!lUJsmnKKbeIp$&{)gwLbT zh)3;A6oWxvp6irNMp7AifMh|o;7xVNk$t8WK-GkJj7bV?(6=v#0g{{H8YN(X z6Ehq^-`D+e?ToVsg}}!hbomfdBSroqZuPQk7G_bIty?^IVbg zJtHns5ZA_%Kd%Cgux|C9G(J|OtnBSYw)&U9>r2U>Estz9V2-V4!Ls?&7a|$;zwd16 zk3ZHrQ&g&7h)8JIm>?ARv?xV`5!~!t$b00>a|}mBro{hKcIcm(2mUqnR_|*g3ff`j zq8?8R`tfm@m>{Vf3{So$5&0X-D&Ku3pbpx3##C33ffT+e`iY0BvSTCzvfskCPt3Rv zXvUI>WIRHY`0NBMhB1(XtQ-U1WCmVeMtgP;A(qqRb7%z}0B z^KY@n6(4N9em++H)9@s*z>XvWP)s)dhC!YbM5Xf!V~t-ejxw4!So|+zQakfo53ZVA zWNK~jThmS)djo#{g3TWz&yuygLJZ$1`H6x@22{Y1 zq?jGH-2K$;m4esDz97D;2~mz;T@uMb;p`+hwG;TKI{zdqwhr_4g6x$sjAR7tQl1v zWz?^$x$QJRd@k#{%qB<67~jUopzc^*E6prJD=eX1{8UHP%PnEgYO4&AAi@EE4J}sJ zqvRJgvz}N;M1MbgG>`T5=a^UAF4i}IHioBxRBi3MFYP^l`f+P_8jk76oA8^N|Lw)lYku>g1!|LF;f z4EeqyyWLw>XM)FSn(~)r%I17S(`*Etb#ItX8(DXZ7&h=f2Nsd=e1DVaiXQc;TX(4t zgLEp7N_{Lf=N~e`oA|vC|4t^zK}>aY?rDb%7=oS_?1^W-!W!KT9irBxDGr&PI&o9g z?&g|Tr>e&k092^aIJ5;K%mZ>#-^=$nMUya>zMJ?)C&8ByJcZJK)cI;mtLvl3ceJ5Y z<)=AOW*+j^(>Wwnwxn7+pVT}UF@$nR*lY;j|78)X15SM2amM0MBKLZo? z55Z;eSbm@ig+`+*c48fkW8qIiG+h%<6*>pw#?oGH0VChf+-i%3i^uQ6_X8azY`LKi zui4gl0JS3fxfHYbchuZQCwH;7LJbBD3tmE5^2W%#H>3#nLn6PG^^>&IW|u=HNY~X zhC|nK?(E;U515lO>r%NyECdX|UEnvqO2vb3*1-wZ`G+h*L8?7vt}`5D6|b>yP%9&> zE~>ua*1nTZqw$~~;-~!iNt^`VSvhksyzcuQ<5@Fc^TUYw0-vaqJtQt&8v|OGuM@D6 zQ?>J1#k!I*eF&xTa^dLvNRizC@O7xnBz;65<%}Ac*Jo@1n^U^Y^$6^g#N<{D>m_g6 zjBup~y|eM%{6iWfOOJabKgt+>u6i3Kr@Tq7pi#t&|Ho89FM3|+$sb{VyyqU$*7IZN22X(&3V{`8~T)2-$#)P}MY-pQEiVZBnNQHZG z1s$Ra4@!i5b#Os%-Pt=U8Fv$1^akT zcmL1S0?4@~XfA0t%rNn)OC6xmX)YlMsu<22Za{D2Lyslt$m^=^RowcvU>*1*)I``s znXSz}g%Z-mBcc7u1NDnZGV6y0Ya}sLQ?_=v3inC#fg^vVn5|bD9!eduk%%7sgDN`O zn&G}~%ztLmG9{D!xiHEgPxW1aiLikp8zAA5Lg_rfgN)G}DqgS-`&u!KMBHEhAAi-n zwN$M|iV6FH-e7^(Jkncb;?>$h{eOH_3)WK7<|#<4#3$Z4YYf_Iq&6+L-{;OaA z?WXcd3sO3)LYjFym6}Uf`+>u%K}Pv`&*qU6ZLj%x3+FHY!$V~!EG57-r=CQJcT{Vs zG;h7FiiICkH!Kj)!$XZk3kT*Yu$>}R(9A{s;)_B0n6S_cK@mwXXnBPxfsC>#&KyiAXyHdGPFQG>pg@MeboRgNc8)`a zz|j3y2#oXJ5SRq+Rtvyoycs598Ym$IS~2pMC3m&?O;|JtKV`?W&wh@TN!zo&T9fP0 zjpgLzFbZD3(T(HoBq26p+{P28HAtO=E!;Xl7j zl{HmqART(!8$?QFfbyMG%h4I~Hb-}(qUZQs*v<1CadYi#Lisrzo))|<;+R<}#w99q z@6bI6v!nbSpgPwAV}6IzrXLSORfI0##Ao}UW_rnA40krQy; z8bwm1)DsIhIb)49RZqXy?$YZon={0}liqpZ`K;nGcR1Bh;UF6psn=^_?&2)l4rvL6 z#1Gb;>sMh=ycNge9V+O#~3nw~#Gg?bgv+H`_LtqRcwQ{PDb2vO}|M~fDJ zeMpeLoaOQT=>LatLr|tov4(&q=wC$m0ty(~F8MdnBj4L$koIE>+p2$MWFphu|E33X zQfWq#U!@a{ws6ZBN%osoQzitp$^pHZO-n(4* zzrZeIOD_B$_+wePjvknc^kXoT)D$L)5`lK5k$4vXy+|ZxK4M)4JtdSk#!4ma)9Zai zimiphNJ^w`%JN2y-RIR6Irb+_`4^vAx;pN^!~Y%fKBIcc&2vP(9EZfbn;PFkv3-@V zZYs1QYWuxNH_4Yl|BikHJ`vOGkSr5~$3B`?&q;oI8FBP7Bpj$1!q8f?zRQLq|MHDe zpH&u~y-xcghr6Dj^NEZ|m+dHA;bjn#$j1knxc?_6kaB7r)pR0I+7T@$glHx3e}kV(;HbHiG4;iHzI8||^q*droF?$0{N7%{r$l*~F3nA|cC)m| zz|ZtA3f~!$!l!?@D+BTPjij;PYW+uZeH`YLX@XeiUu%6$Cj`YJL9pvJ(pn$dWeMml z!j9~!b6}+)C(P3JX?kqyrA-$VT|D?1C$ZyqYn&|lfz3Z|X~jx|#)1BWTg2{!fjlIr zJRWIiw%>=bpwLIG#2>(2k%SlQL}PLnP3lh?=B$ysA@Gozc{Fp$@OaNZvTYt_K-qMssma!Xr7OA;-HYWBEtkH)q2Q{c|&3cO)=7|T0J&? z*$vDjAo{_~zo6@CblPU5ggg6I_u`o5gv+3%zt`NML5Kc8ygj_{?6a%3v3^^p= zllSZ+e8KriGDkC#2J)z+l7GR3(pppx~utfy&1| zlqHA$Px1X2C`;gR)sud=06_NHaOe9Fbww}N0bFs`__Qa_qtv5=uLjgnKfeNZP$sBv z{^cgj3#4uSiyQS_G@ znj>vgp+Y?^czLVX+Pa$28v0^2!q#$2MX+gEl0JQfkww$zW%jm&&EDwMpO1Ejfv*>&U{3-x}g^*xCxEW@IWcCF56< zT3UHlSnoJ88@`PM$b~A1x$Vs2OIkdq-Q@dphX>~LooY7;}vr>oAqNLBvtf4B3D zjzS@YHeP)QcP?wT;hS~7Ckpl%m@Y2|K1VJzH!AFlF1OF?I9iG!zP%vJt9MU}3%Zq}bMO-@B1IJm zq6*}g@p3Q>s>4M+I;rd<_$>=iavd4Il#_YkZ&S;2|NXvZ0}SPmb}lrb=o&o5s$XQU zqarC}xf#q6uC6Vx$quAF-ZzFu3^nojpY&;yp=?Q6UnkyggqSvsehDQI!p&}(=PIOp z6G9^kLfV>b)O@XE)3wE9)MCtWZ%sEXIGbfM@=L+rcTK$$CW6l33OP}nqlfQ3I zN4l9W+Gj-4x*%C9iQi#8t%|St_h);HPA~mRXa=p6&z&0FE4*n$m` z9{~p`)T zI(w#h=IFw+UE1v(E0n-v85Y-~`y98L-dMyH#o18fCyUZ`Oubyc*ptzfGxbZr>*eig)A$Pej=~>mhI7 z(;43n56_?Wf}eaqo2qT}F`TW{FDy_5b7W;lr*&=PSiHV3xVPGau8ODKZl`O!z6TXA zPx`@;n}OHd$qf%rZ?iU&#qtx(*wilN3HBl-_-v zu;PRk@@6L~*uOD_3lXuGL-M@PW(e4n3{F$fb4tz(nh13+9Z3fg161z#H^(LdI^JyK za2eE+dnT3q5p%=V6MSwlS5$6CUU!uC1zpbKcve6fxMAg=2wFH2U~Igt!IfCoGxwF@1k0Ep3c45ra*h$ z8A1Dwqiqc}^~<)@O}{2cWm;Vw)n{bxqK?z zcvc4jtg@G}U*8HEm5fn+jTx5=tc6WGySp?>-_`jBxAo?-q&PT^pA{p|dlWvV{(62T zu+iwDx8IvTVbJQHC1xo!?w{p|e8$C`p5LJXzs|JQ7uv}4GU)yT zg}EgQ{_dem$X624@eok_!u9F)k_$VzC~ts&V~6j(Q4HsHM(!{4K0&p7oPd;+H{AF8 z+b+$zmA-~f(AnKpgWF#jH|&{kg}trtvh=G%T`>f6V@oq|Zst{R_vTnlUW;3*?CJEL za!dJa^Ypsc;rq13tb#r#N)en@=(IWPwX;6Rj6O@m+H+2FraJ3kEOOKMx7BN#re1#t8Yw-T?5OJ_d!JU?@NOApv) zHo|3CGqr$xEBS5+_(#pkeVy2Wcdws5Kj#N}_|`6b@S3|Ry7_cb-delWmkg)&HE|d+ zg48###vx8dk&V1y|FQiH9_`25xcha5+FP#WC=+@Ldwa5vP0Ijet_(;&y}L$r_>G0J zSR0iSDCP)BKM%M-b=X5?axxlS1 zQIYPA=aUz!n-!3S!~xI~ zAP+*KkhJ-akpmvVvguw7B?w~~bD6t1m1dr2V^bVqXV!spG=e5hq^~D&`W8f@JEV%D zOn^3mes|xU$Tq@@_vaCh@b}%SmuY~7?M@B)C$7J_$ex;jq5YYaGtvZ7Kxb)A%0BE| z;fjYqdIz&}EImxt<&z)hnU{%dL7^_1H4MJ>tyHRsj<9cv4Yd;D8wPnpgIae;)RH$y z)9}Kq-eu&jAkq2HR159(WV-%({f@vV9 zhoS7d(PI}4nS|>7kLA0hD<;=XFJa_xv*c)pJ-5LIu!yA|OSRf8UHTZ$MURFp&c|F$ z`xIiPyjr!&Q<8Mg@HDK^qK;j_thdKMfZ3bmm~&d=a@&Z1M)4Dsgj95--!oy)O0YCZ zx-GUe+4&lnj#?vlJizURO01NmoBTGg@pUa6GWQib=!Soo9c$HmLFeh*c}*c#!AtvC z^9mW8EVakiSm(wx*W<~WzE9LD29LoLzZ^L5><2fWhBftkRSkV>sL{IywEYOK4x(Su z$m8FhUw$rgay=F)Dy8AiR@_}=2t2UF$N4`dq3|S3LAx$-!A9J!x3O={gYHacKqGND zGUd=;ziI(20`FORVy49zRif%Kt1oGuGxD&kHnAhXh`y~ve_Xx60B)dB#gNiv4+(;u z+gDqDQ{VS}6&OM(+lm8pOGzVg9e&F!XZpmIZ{RyHlExx;UYL52G=~sSRcf$sw5J~s z?pszBEGoV^fTE-v7}9CD$W!FwuYGw1#8=Geq>s-LdvSb{7DPqAXF zzr8xEf_!-+T89~LHUr8IFh!tZn5<5TG@c`D>XQrN4&|m0^QC~oO$*P-H_nWOZB&VJ zQx^DoGWTYY&wLp{j=@dkuC+Wu0!~_6Cy|%^m~e83r6h5~hs?Ze->2^JYhUAMag+2p zVGk$WH!p763b>lK>Qzwn<;Ge0ho4A6(HO%_H7z=U3-Vj9YmsqB*V^v9(u}*$RJYET z^N#V=9~Ubuxt>cbJIG{z;|s_t>Ap*4Q38dCZKpd{^Bu4Me5UU z{9Wy=63;Wvjj9x+|9D#|iOYLXpp3cGC`W%@d1j6scZP{PPvQt?_(q7 zL-UStoQ7HadKMki)g5Bs+JSLb^eq%aTAb#C31BbU@%0|)a77)mh6x;?n^pcuk2O5X z?OP6Z`Kym;U8T*qke>AZ{eIm>c6#aZBB5~)8wr$!`A(*{*#w1>IR1xBoa4X7?jEU$ z7;iEBjPTm3&L-lzeDw+}bssBpdhZ?~v4hDlmfk0;PvDM7yhdMZBf+hA=&x$hC|b{o zD15<9mdfU$a^M_HDmDzr%iAcNi3}((*bK7ajIlMDDN9>;cA?4mn zw-jo$yEQwlT`R*!zI7z;a_%$kT@mmI9un3f)A1SJTUH#vo>t6i%4hecqSQtMb=2rk z3oZt!1`iVC*F)@LrR(TPL}4ua*TC|Kdn2PwR{gu>a(&SBRz0j6NijA%ZYVj%2pn+~ zrtni4Xq2%6{W7^;^&{TDC73pq%th15QQZ9U%3bDB;Fq1Qm)}6BCI~_g%q-aCYchGux z|MaEYjkA}?jwR2#6-SkU(XtY~=6sm zIf}#ko9_BLQ!m})Z&}oWlQ=zNQek}LW5R}1$6|OoXCLwi&?;T(o?DreNhb*UPkQkD z+I7t8S;Z{g&FY{pT|m&Iw*%X0&?n26_X?96x{xP$p58F7n$%(&(b=n}8=1FTCX0J} zkxo}DO2_nwN=Ol1+rgFD&mpJD{mu01R!aQh-}DV98pHc&_k$E4Jg5nbzSp1lVImwJ z-lyPA)5$9=n@HhsZ|zZz!I&qhO9Ue~XUEka`^+xi(Q`LDdA9CtDFVkiBGXMiY_q(@ z-6bX`a;G6PvkYe#I2|+%#qSKqfAe)>bCuK zA6kCPp+m>ojkiyqmY>apci$cJ^xuBPNWr-~O)*_1~ zBlVXYEFaiPL(u~-ZW(5e+L`9k$!skdv#`x;Ee_`*VE0!9z{BwGcKGh<`n~s+4CF#_ zPV)Olm$FfuQ591q=PPKoBWT-<=fvlezHe_6@_^oN*xCuhN_95A(>HE&G>C^$7l)Hi zHita=jvyGo>5r(A)}cQ5onq%%y5W(d--#q??8CajSNnAAb2UxIu0W1UCokMhP;H-% zbh$P|+edu9_&B};Xy%3{Wpy$? zOaIvGPEYhq)HS@>*?nHmxZiK_csa)@ic={|^Na(iGBp2f_22T29!JZ3(_H|kLuBeCL|>b!RWG)Tvsw?!M&kr&@Q^QMZR&0x7i+*y_8&SP z?nLJw1UhvRZbYZrs+`b|SjX=;KL(cfx4(75{~&i%mJvewese$8lZbi`x-zo(20&b3 zEa*TDcv~tTc1KG}VIY^!qn-tCk!HbSx+M$5h4O+`_;p3hW$ezL9z0*<4;a2wG>CU) zxp`i{B-6?uylg}Kf%+KP)|?;W0{pNA9})P8cfH=fVD>v0+4fxMOAcn?HSON>y0yQ> z*NIRs=+{cPZ$K{JG;Y#hKo0eJzYM?8h>Fj{*4>ioJl^f3S#M^0!|g@b{0}G|it`lo zQ+t~(Vi&KjqGlstWpmCSh z8%%xEPjKDPl!VwFy&JttvtFaV&6i=6vQ$G%Qrl_+;MR@4hf{!w1nhDM_=UI}jq^a~ z{>YHZxI`ffcq9Pe)sq?b^Zti&XK7@KXB`m-oR;IyTq<9w0xD?p|-$os?g zOe`Yt4KRMY`{VMVP;m}VQ)zsK;Nc={kti#Y@u&{sr*KdY@#{Wr$csxh7hyP07ObaV zY!8-jSggG#Y1{>Ej_t#a?ow+&U9UfsGj6tP_Mq>8s+8-=Ewv5xy>;1h^`A%|q zo2CT(Lz<{Be;s*v|B5cP`_^YMR&H^DPG$o^06FDl4R>nfvUcu>rPpT54|mXK`#4Kx zNCY4o6YhsOU^)}CF$3<`82&w6|bGXZc@XJ6elziXW=H?guWV|7JKn%7L4VF8WuJbZ z;BU5)OTQo!EAGYSwgTEU39)}`j5Q(D!DSh}PYacLr>nwb<1=0`!eA|8_TyK|}R;k^zyt_qci)gNP z&4j0atz*9~b?$-RuCChEE=x=L7*Cb)7WwKAmFCz=bJ`!qEAD;5$#DuSrV-xkwy$4+ zNI+_aPif+0l>^-dahn^>74xeh%k*DMCC0zy`Q@#D-8s<9KGgd-EK{Z}V+=g&&#Ui( zRy*;9Jd8lPaIc4{@uI5gL1f@EF`FNsy$3eqVRFpcWkvUsUg!Je@b2mc2>g2a{sH8q zU!J$(!G7Yrhoh+rx@x7tUS8Pe_{r@ua$LDJ%p+NURBdAGAk%MqA@nX8w-$dSSZgLY zwo$YUtNKHYr+ISX@WO&5LrvW^|*gYF#AbYX!lONv+FD)0P zoT-{`uJ(r|nW@7N7pb{P+GaO0<}aUjfBW{j@J+e?;zao=RV_{;d(%3AOf1C6tYeC2MG)%e+$q=ayKNFDuRET&lV(0k^_j%8+S)ZY5ik z0B%JvH%)SOH};KT>XOBcVbQN9F#%KP^hNaN-H)*7f@vYIw|_Q<;D#;d2@S=9TS~Gr!_GD!1OP9^)l9*ak8Tw*e31g{1A7n_PI+<@%I3 zVE=!_0g&=+){Y@|n#K?fJ>tMmiols0da2nPdh)m1ykE1=#S!a_`*(3_W#=ievp^=| zeW&L`|K{vX6vj~nvRWPTY8^9sAs(2C`00SWd^6i^owJZN9{$!UJ*TgS=aJV43M1a%H?v=h^lwd@lSLM!bl?*<7oUr(dDCSPPhl zZ{aax6iAuA=HvHbkj7Ov4&jYYIUe$-$Y|N2W7(-)F=bP|(!EstMu&3{`IdHeMlH0s zydYfbP1LTr>yWr#Wa`HBIUh54RT5X_tsrlF{JN@dYI5Bxx~;7$X~;tzU__dppFg@< zxT4eF?(bayjYaf8_q%tYP2FYJ1fvvyec!d3Odo+=wEir}fb8Vx)=tfaFF!QBf8+Pz zT75E*g7BggX-Ad5;-x6KdM}&`ASg%LcXJE$!pHYHwp42@xjh-a9wF|_6citDHXmHl zyemzUVCMHHRYh5Cl9E86|3X;`B3WE)2UUN=MFw(pihytSheO+&5tD%Q-ERBC#bmEc z1Kj0(273snr&~eXjMD=xh^uB}n6q{gfoG%XgHaQueURF( zs|Ob!B2#dnVrT%0=~!S!D9yugQe0MpXveM%_<^@DH49=2NQnSLOsywuyF9elQ#0P% zhR+x0*j?*ZHRdzvARhY3kiB@n&-C8cJ!@wlzN>ufwa~D0Zr5MR8~9_!Y(EZC=Crg zhexC>h@{C8Fs5UokxQ@LvWK@o7G`<#>rM1N7XGGhf|zNvADZ1QU!)|z6Bp5;C<5t6 z89PIrAFKu4jfXXt^nVR`EkTFHz2`-jXF5piI5^iL`DkbQhrzq;URh73t(m3b%eI^R zPE*MZ+(F@owW!e8C10sF#}jD>SY+yM5?m3<@__*JPfTX6NwBIoA0i+1!VpzAVhBgR z_#Y1mU5a_`fOA3dXk9?-qRSAh+pAUlUlpd#!#`#m)cGzzFv%6x{iy3w%ALmh!jphD70u9>Ky}6w(0yK` zj?dXubmUU%F)c}aBS7%}m4k_1_^39_wIw4Cz8wR2kudG3#7eY&-gil_GIbI`xG#7+ zLBRG|yfpRZ!zt4vzc-s!MvDtYHoG)sSRX3kUG(YM7xwvZ6O5p!$<d$g^mT*~e~uVJrm5{5KI<@m|dUm?cYw1@7mgbIJj#=j2`*kgBD%Rl_xvtMdEtt z7x7I4ug=X(X=mEY2=bX=p2|Q&R?!@!TUrIXm zc%@MzZ$(nZ-hbtka_b$q9pVP@@rH_*8W0YJoMm*;$@T48kur`&ur~;^C|Ksng9R|Hh(liwFUb*{(UkIk@g!t z4qNB_emwrV`M~y}W2yi=;IO`lQ#&hju-|`pyY6*f^C0>beJuvFzdCA%EY%0gck&>D zy6tHn?>XwwJZZpPm7l?Hz~8_!^vnm+gQ_JlM~2}lHE$UKEF>w^!bCg^0D^v!0Pzfg(^)nHBxAd&sy-k$2Vyn_FS z=(~HrW}YV-Q)4Y*Vaw(8aWbISA_g-)*BE-e+kv$?9JbU8k8L-)^8$X+Iu99mO@jOCX;+%@|ay)!`*M+X6?i`Yw zIoZ9@{7TDZwi)Ka+3=;#06|Pu{m)*;IPTkvbs?5NLJ`J?m(&*5Na>Zs?)QPc{XN;h zlwBk6%ZWd5eIdp7Z9^InCiQyTVd-VMVGh>2ub>amH* zKcj!O&Uh71+2oQ&%MjAet8aGdsXAHY{}HcYnPlDRs{9v@ZOv`PO45kaa{Wl`=T5+s zR(PZ(b0KYZqGBI5d$td5?!`PZ1izg76TXK7@SjxbUSU(YngI`Io~;mekr8XU7xeAu z({67A%TDpa{|+H_wb=Ff!^A^I*AKqw!A9O^(}4xEar>+dS^wm^Yx7eR6lVIy;KGL= zc88lvz>?KXOJ1(gNv}%^e@1zVxT36_)9W|eSKp4HIe*;>pSU)g3GZJQrhGUC#$JpP zWS@#Oj~A!h2Vt$$(b6a|2l%g)w)3y&hh09Rynz672PZDuPSp?0qFa!c_m7W}!$0r` z`VXU|o9maxqs zgz_Hw4!c4&W-R@sP9<)DWwRQpBf4FfhV7yWhp1;w^-EkFLumK>9e}1!um16YIhTpe03km1gO|;)VKDqLLsQGFU6r!P;ihu|K7wo4TZ z;!);Z)Lv*JGUyi$Rp3nYJ7kJzM70S>OnzNGZqxDJYT2xbe2*TGL@^ugF%u=_Oh>S~ zrI`&00qeVNnJ4r+7DZ{->8KvM=MNpBCu-UHs+PdC-u1M6OO9B3#SP-I_DBB3{{@-C B^c(;H delta 48674 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 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_00.png b/public/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_00.png new file mode 100644 index 0000000000000000000000000000000000000000..525727b96c4227e7bae462f4942ab32e3e7e44f2 GIT binary patch literal 13102 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_02.png b/public/images/api/qiskit-ibm-runtime/0.31/fake_provider-1_02.png new file mode 100644 index 0000000000000000000000000000000000000000..8257ae55c6569b0d8f4451a18eccac18818eaf87 GIT binary patch literal 11442 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_0_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_0_0.png new file mode 100644 index 0000000000000000000000000000000000000000..e8bb0d80c690b8d2a2eaf035b095479bf25857f3 GIT binary patch literal 58146 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

`Z zME?}!0hqnnfIH0GN(YsZgTyr)ju(M(#@IILGK0#{4cOxLX(q2JUmd<2a7piKgsg37UVR+ijV1wVhr?- zjlKkl+IVfe1ubS8n3n>E53135VV7T51>~funmz%IWssjGg(}!(K{vh=VA9Nj3c}yK z2>>B8WDXN#+V0x?6w6Xy&2H)F$Zy+m!e*Cm=2aPTF!!XoGE2+0LuQqCd?gHviF-fL zs|Le4EKGywb-Vm{hMIx&7k)}ev{G{D@2AQHH%4wcYelNY)IOxOSp1d7UyxlY ziW+%)Aais&aLxddOtHRFDlrPdmDY(-N+*;)xqHol?$6k&|JB>gMj zGnvE=?sK_aWS%hnu$lO-^nikbLT5Owda-}&WAfRC`**zE(NYenOGb^ZL0bM`|aGZp-<^`OKs`+dMj8h=t z5nx9!nSbM9vH*^`xp~PK4V{6tm!o{k7QD)q&0XH0mxzd2F|CmjlB4ra6}j8cDZTl(D%n5yyUUiPSY?)2&469~X({M#Dox zqq+L=4k}>kGNPppO}BXDN7FJn5ED1}V2IfzQ;=*q>_SXpDqOFUSzi78L_f0$8P^A= z`TCgU)I^3?LUKC}oV|Xbq4Jk&rb~05wqssLXS)$I#}*s1_dc4cB}>on+c&GDV>!`Y zG5!dufvY?fXK$@krVa1-iPi5GI0;Lzd^Uf8P7_0l({|8aT6KBk`&njE`^K;>b~7>& z8cv2Yj7>9mHLB|e_k_&iZC}jgC*qgooIENU?#JyX`J1RF)NdkBSBFb-S{zjGfN1k$ zqG#(D@bK8UyT}O%74wedwUuk)!ZRab7!d=dQlJwQ8ag-C3#PEh+PHB;{G;K37$N7q zdsjdl4~`%KHy9%_>+1vd3&NsTSa5;th)(j&u**nRSj1l^q)87!!RODm_3z)li z?L6mYn%(+Gc(SUh3VPgOJ}$pBn12_5YwL|n8rTG#m2?$aRiiZnMGNR1~ z!N~#f7W^Yt3EQj$36oShHNYJvgQRjtegDe~H1KLgAt@lYoxht@M}oS?TB z%Ug1!qXW@n-(rib*kV_X7v)hw(*@gQs+B=Zq%fJ0lN0dQ#4jd+sid9i1<2O;Z%#b? zJUp=$HGD$Dmv-L=KNHF@D!OiN0!ad_>f{r zg}>RTz<)y!@IPL(tQy7gTRGiOMGr_-qC z7&zl7oi<_7Ll}>EHNXJiBp_+36ef%MG$)7TN*4S7-E)LvN+gYN-5oh2l_3DdB zPR4_T5z3DZZMmC!63VhgB%qor3U0Yy&Mwiy?7K%yjH*9X=9i*>BOC)kMl*VN9PBi% z6J=jzp0?$ACliP6?(Pou!9?H(nr}NQ@&=5R!6JngIxXqw*X~^kT%HO%KItOoUrq3j zk6R9bjPV_~kkJDO3Rfc8Pw5!fd7{d zct3_!_%8ASRW}bS0ty6Rn(7U^fW{*D?%o7tU1~($5J1Kzm<5X*K`t`buar>u`epJZ zw^?{$7$;xH+A1*3<7Z{hHGUjK5dfDIK1=B(e=#PUD*(hm83#m7Dk>_Zp$Z0i-U1LN zd%@{{A!S(~BYP1t6_kf^j*33alwE}sxHO1gtS@&<^)?*-^dNBcQ|~kcaauvq^bd%? z&nN)FF-<7QAOT+eiwO)=o7PIFT|*UuL4fkjO_o8>N`7l2^S@&Aw3Muuui}KA}+$Y-|2@S7m~u zzPgjvgc89f842@1w$&^rfQiI)nq$@Sgj5vosG#uxcsEcjS>Ad5k}ufr?~6K`=Y-bk}yyv|CNs9{Pq`nJ|0ILJa>L< z5GlAQSc-kV_E}VO-RaaP>C@1j-85B1Ypz9X$t%w{%#oWgu`VICmK*dxGJ~1hI_kal zS!ut=2u)P76P;C*yhN`zWK6C#ek?w}4&OnJAhGe1#owFr$RF!?A@;+?&6gsm?<3?WP(CZ)w52>^sp^$5u(!r1&x zwN6CG%xGu)A{`y85g5RNg~!v(0w>9VVl)96F?g}ibt=!Z2h)nDdLKlxcZ_O6ELCMPBK(3Wu4$0L;Rp)r}+SyZ>+1gCr)pdYx(lLxO8@fQ|_;J#{$x>Ats-arQ=Co$%`5Ueff z<*7UQ*R(*4G9$!2yO$k0jF-bsb?PTpj6N0g+(U}2yEPgy>ixA6%wSxYwY+gKzjvw6 z$yH2jM;-J%AOa0)li58f2w?~-i~Od{sF77`fG`%&g*9vOf8Ytlp2l$@l+bXEB-r^j!E37a61sqjI!Twj&FGbEAjH2lVQ^5xLN>!Ls*ZLRziNL3MSCqv+nS+q!hu9b;Aio7dz)M=>Zo)9X!-`XEej-UIlIw1a1J(&k>@HcG+vOp^!OkC}9CQi-y8?Kf&c=JV5+uf`0H;`u-(8=w#Hyb!6t(3+8u| zJ6%bBJUdLKZj)Yj+F6)OlJoP=UBarO`%#u!zTJGT*kt&F4}D&uMm0Z0{$rP?wm)O8 zf?V*gJ#-4!0H^AC?pv=Mz}!dB4--`$IPbF?z&P31IFsSl<}YAR2G8Od`QH0OpqLsl z1^#;KT~aN)pueg&*F#7ak`zg%`uSDW({0Q53Eny79R~aA6)hV&5RhhCR1k1K*w*V~ zH}yzQdvi7r&hFk$o9p;2P%Gg0Y*jw zR6tz^cs1Y+<*km93032jdzUYjqrEVV0|g#@-UBBTq6doX=l2f^#BJ9fKlBlIc$rm5 zH4aMH*1_gJo%1q?;=>QD8|VC;e5zf@>>KG~-z=tC-hNlpIZDgK z=APURC5!U=k&&QAPZ#h( zi21A`A?Q8=O28!H^{}A}Fu<9jfngf7G${Q#fHkV**%;F3#L+glaBqkRqAFN#^HE7i zxTs_uT(H|j>Kbt)*hRKB_J%WywAq%>3*ggc`LST&DJA*_oAO~^^qWv0kUMG}Wt9Ei z6i1fRI$GMW-)FnT5-HhgsR;z>&%w;AQNe7}A&<`OPet19ckl|%)LFal;aR!w$z?1d z=n5TOHzOcBl0xC>_7}(Zu2LMTSgs%bqbMI4fkKx&s$J)bw^fd@vgs)jODtt`hwYu# z82kIp^FTDqY2JSk6LaTK3YRXs?k`1nkk><7G2K!r*<~vrWhDsXMcmpvES1Mk!C~|H zhn)`x=TAnO9|4uS{}E_n+95kT}50dfBN`nwZ%y8geT+M?depQA*}dY~-$fag0} zp2CF_!GUj%p_%A^hrXb{4I@oNB{V|{Hy@{kw+;<`ZWLaONql5G^fhzYmMvFxdOA`& zc##NX8}{u|7^gBXfU)!IyZ4z1P;ipVoIiaue~VLOzz-wnQXk1q*2)Wl5y0e6+ZxYM z*YOwj7V*x{SEtj05jFS|!-zCEQV{W8q{}uQ+=V2{l5uqqx2VTBs`d3DUdp)ukFR4Z zr^8iSzcRBAPp8(tiHHz>#vMwXMncKNhRoQ&h^1+Gv zRwl)&s$Lc=!}!9v;$BrCxjy@wCpw22mXDvN$hcW1Ji^azH01c!o;NGt$5L5&$xj^0 zPjAN9DVme1Q1DeByih9nt!HXZzQaOcWBG+GnN5M#!T8M*)2kH|6q7x&?FM1_L@nVj zM55bA3{Og6wFePmmSB!Ei-7FKAmUYd*tTfBhDO5`j zh%uCsjo`6KW2veuS#VsK7?65}#!dYan0*wg{L^rmbpd1{H*VeP9Lk7no$iu+cjEeF zXnp5<(Al#b1;47=m`_%VE9F0G8DK_^7%x&Vo&EJ-;@nc(q<%&E05xafVK`jMAG zJ@tZ|@*&tq_hl-iO|Px3E!#37uVsG3qK^CS+h)6CT-i!!N0ObR`ctu|p;`wMv@!SA zLT@mXw=}?QoY|cmGWN0VPenxr*Lji6&hr@-4tW!$cg%OE&B<+bB4_yx^ z&Sbw%Ax7R)o;D&UKxV8;daPYBJ%H0Vk&jDBp*i0F?%og6pzY({C@XRo+_$N}-^k-i z+r)$}RD?TjVxSUyz6*~A4)P*Di+o+A`~6|yk6yp;9Q>)C=J%rpf4t@Q`-G^WHs7%ocDxxPI%FJQWp{S$DcW98R2evoa#4 ze_l<>s^jJlqo+R`&pRx1i$5E+@s)K3w1MFU9o=Uu8F5#fAuz&?ii}JL@#q^gG(u(L zPB{+~c{89=d*kX=@wMu$U{JBzx5N1B^@I{XzwReTYz@J*e8CG(;Df2$!-vrfuY7$+ zf{+h&*lz8XhI8f4bwNR0kRuz&*RG0;i_40PByw0A*M2XT++W~+Y;GKL{`bclq(P+W zO!8{6s9of}FmV*2L})SWygi@#Y{FGF+#Uo`DfymvlFj_J%222$*`&he_wW0FmrN$8 zmN_gBDvXbhZ*FcXK7U?L!lIS}nnYFXP(b5|lWF<-Ro>RN2-+l>fE2xOc4nrd6G?X2 zlzL?s-);oOWRpfe0_=0=LVbOG0lVNd>7-#*FKRUEfF4S#A;%3?*7jNQ;9L`jX`RG& zgTm3!7f}Dpt*d*!@e?QR((lio`Pzw~xOV;X1*g@Dxoyy$`r6m03@&t!z~d4`tpwU* z*+s#a=_8LI8=D;98=E^jePC(=6X9%E85x=2dV@BHw3JjAuuPG$v1+p}(1GrT1C!Hf z+ayo@<9#5 z=BuUUb~43MP*YU9IG*#d25>mI9ttutf#7niGBv>cro9EWXkTi#OsNP)sc=xIW22@{ zCQrWb`;$LasyU|tP0Ji89=8~B3>EJ!_C44ewF_ZbsQ1L^-|bE*$;^}l7tLNMi{(8A zYMcvXe54eOjNXlDxgSkYmp~tX?8RK7w2VwIc)XbPOn}vCd))12tNf)s4F`Moe&lmO zfm8C*wTDV7D$xc82HC~frA*+0%nD1nqOuaXk9hpspK9&Qhg*I@YAYH{bm0grw4?xa+P@GKk~oFLa&wG_2#H=L_}`^|1~ zF=x$I$Gy$<^-gFCEK_||ir(DSa4>X-NOzA(3RzqcaspYvSbl47mj%!GWF6NXSUFC ztt>PQ%uL`9eDeQ16}{=a)WueVAA~`VtsfpQX1)SwoApn`VCF$vl67ko{w5XPo|GM4 zY&#fP4|6cq!|e*rD6OyHh0O3b3bFg6`Rp@+a*^Z<#s zQp%Va4DYMtECb7$Q6@G8YVG&<3K(#x1+<`+UPk2(znar>VRNxrA5-F88xasK3=$n! z>C1_MCl99&6NRGSw%w$jUYW{C7^Q%&!w}`vY_oI9$rP8xV2e}D3p~`$h2$yXt*xyd zXpB>mYrgmD2T9E9H*Y?Kr_<@zq%Ri~vXSix-Z}=Nr|#}Eiv9Qe*`C0zxDFqr?Jf$RA3ixB(;){n`6jzTg$+#bL?9yvOe-mxCH z!148Z`Lee_S1?bzN`?M@U}kqsWCnN_Dr@vHO96C~<}l)6zLawVy8E4^x-O}}5t{(l zsZr-vvs!z&YNmUQn_G2gXoyRP8imRvx0CYU830eBs>h>8aAvz#``~D*7jUnkrMOMn zRqysLq&PtHi;0D$7ra9_Er&U)PS|RHiG+h`yy}bR&n3g*Gb?Lp<$`2}Z5?kNfF@GA z!sZLo-R7!+D%0Ry2S2I=yU_H?ilwC-$S;8=54d!(0CV()eP)Npwjdn(Z@kEoxx);m zv@1FAf#*SugPW)rc6$|Qu@-Ds=jO7&#g(e8eEkb{Mf>L+ufcRx3~HqZ+dXno;o(2! zI~V8XR4+uKp**r}_a`vKwY9Y2cr$qx_=bAT^B`p4gFf@p&MZHihc3aYZIX^k#$Ns5 z;e<;A->=CfSqxa;c~fHW1zSoHHnx%)d$@!n`O5P0DfAM-U&qF@p~Y6V6p@Yy0%kRB zsx+zW39AK<=h$rZWAnNdr&_Lf>sV-w1rxyd!)s8Uo;tVXR=k-SSyf<0Yi^LH7s)>_b?grW=SUOzB9TXYw-;eC9 zz&r>n{XRfT`_d%v#vBH;eP+>re-tytL>!H)rv16<;rRmV5d6!7hKmXuhmh~GuxeK- zkpzf?IvZngu34vs%DIEK+ut*dzbC;HmH?0>9du}R7J4K=K@1xgw;ymlVtjl(Zq*l> zSdk@fOR5DVR+Yo!xvld7;TvuTIGU`)r0Z>)pjQiWoj_sT3=ZFnxjR;)YVeO?aBPa& zX(P7mPLr=ld$S&0D*>N%;9Hyp+Wd z2Pq>98CHWmyp=0J%77`w!i-ZI1YMcw>0*?;_Mrs@1?f3>Pk8NS1HsMAbPV%{6Y<$R z0Re&Gq9*}>%)STA6Uhz^_ts*DEc!vNve;$cc8TdbtdV2Lpo9HvmRuoWMQq9~>-#o!4;HvjS;pX?xfjmx8#*<>Aj! z)GDwQB44A|9d`BAGN9k}7Gb7_j0@E)f?*3<9?n-CY6t~25ad=YVfSoCa;u7SDXHi> ztd{hC&~HHE#wSmn+_-*SGQ1d|CRiy-U@MoqPPG^hzXx)xbzYL=n_LE~LgdTCEUSlE zL!n~gc=g%l-rfLwuoBoAkjM(u`WJiNhrpo2>hk8F@5b~@DM{Lb00=1dnYFb7-Qz{o zgB5G{9O!|Y!fms)nVk76<3ORTym{*!P)q}m;X%04F$Bgee|_PQJfQj$3I1Oe{Qs2` z!|(8aL!$Ek`e!Y{RAV9GvK&@|><3bUQq#Siov3ey-5}wr$NjEa;LqLOxgczg1Ec%B zFl_<>(|ZUPG)I8x&xVNNEG8zXoT}V;%(Up02UM{pycGNo0^W|BSigV%!xRKwR+wN) zDIarF+rF9d*|x~A}u#5_4+0Q_qkXx2T3{E@1GEQbxy;)9>T_`=xC#Xq=W<( zDQrBv0u^ev-NT7f9Z1OFRBAv@KjWC+`4B47KM%uW6B2U4 zvX}`rPRMK^_V2uw?4mfCVDwQPwl{Ki18>MxrY9#;fm*^L=ahU9%~BZm5wbPNcpP&y zDAl_bzt-@+`C^c@VLm%Iw^Z0n^$67FVEw924g9$>W{MCq>pq`6%MXF_0bu{ri;LNC zA|k;g5(`38Jk@5ZX(%BXy7<-Ae6Z`7?JOdROAO?Kup`sR$;oA;rz6W8!e$n`TG%2@ z!I_a9&Q{p@>7PA&1`~$JISdLg2RtXqXAwcGAb$qMnYwQc;s@j{C&q#-t`5f zH~<(o{LwfB5@d&8>-sCB6_3cs$bf2&ffF|8yTG9gxQQn29Ca7W=+?TZBZnG9)RAxA zT~h?QTzeys?JGLo{uUI^Ki8H_c>3%FKtnXqcd z4a2!tQGRsPtghqy#I>(R)z}$M2MBE5!sI91Zs1g+ z;JU%!0aM<~JV}UB;as4@!^5iqEiSG{48Jdj4!n#w(R&~tCCnjT&;Pp$CtZ2Zg(sQO9l z8b@Wj7pSYNYkbi2bX*-p3IK4h^$#Xx!GBcdWfKt4fsl5%+$IfTuSh6Azz~q{tQLGX zF2&sx2!j>iXni_Q{`>RQ2dT_?^+Q>~1i&EP7n_E!=CrT0MEy%?2*Aaz5MV8iRh5x* znWe+IqLQ_mefgH2P)W0)p`poV@AJbj!co#p#cMAK5%XJ!)V7yDephjJQQn4}5^#$W zTX^i`E5ag9X{@PrXQpRiEd1;0Wp2T7j2-F%{RWl(rFLgjrtU9_f>>D404}d|4niEU zI#?)bV`IYvHx-5!Kq#p>2N-8FaJ2{H^2q4ucOO37f|tL+!Xg7`L@MCP5Igl|vCN!J zgvq)XhA&^fC}-8aeM^_|?p+J~#VEiN{(=-n@@wAy6%t|MQe-A1P)Mn&M)wN z-!RIM8nS$byhYW1@MX`0+Kj_uuM})+{kzC_laOS?T7=?F5!oXhBy0M%s;|Li3PRFm zARm`8hr}XGOw!$b%8k~w`|m`zTmc-jwXx}nWq-VUa8s+C1_`0xfL1y%|9I5V1qIe6 zv)3u1Fp$tN0FmkgY3W>D z!DPM{McQ=`oWZ`pAO!|AP&cr|$hWLg5f=6grr@E2D+USTSiW31W2^Z^7C;2l|({rh1HicGbKgn>ZxX>%m0u{EG%Y! z%f9|^iNrvq9@J)Fj&T42{t`%=D=NSZF&So)NCGn2+)s|?1RsP0>XmCbAlP>C_X>L& z&3mO72sDit<~qRA`e}+je2|CWuNOk_yi^^Bm;JBNTf^ujH0B=2$P_QMc69U~?Qc22 zSf{z>3r{l#)nZOF zAiUUOhyyvs!Ar-i=UoseY-d18s>PrXX!jxSXk{FYR&3$q7qetYkPZQQ52!anX}tic zcXDznefsn%p5M6?PQ&F{ChH}SB9-Fkfw`|W{m~V6b4;L404qFydlZ6Aa~QHH*phwtsK#Hrt5 z!q#wgaVdr|M5qibly_3<`O0v9XKHt8|{=iNa#&hRL4X|I^-=$3wmU`%kCs zY;vk29WBnHjnZjT6lsx$7L|Q%Cld;zkfqM4PD*M@ibx{E7*koYgigMt$ZiPXbW#|5 z88TzJ&lfuP_q+G|{e8dp_xpYy_j~XC`Qt3bnE8C(pV#~K++J^$O?f+NE#-s;W?sV7 zic_;uE=QR0p;wu^BUBcRH^NcO?e_Mu`G*0+iBpUgjx^9qzaGP1ejJ-lkb7UzI$2_B z53SW1eh1pwYl}Q4+cj2?ydy?|akS#8ksoA;N39uR?D4%**B5>KmT?mkNAR8Rnlb$0 z*J14Z>i>W1KkF4J$9d%uIMo7_XcICjYOUy+&}v999II7R3*cM2jehae6Ev|6H4s7RjVw&m@?l0L{-gHge5`BB91**UEPcr zTkHT}yX9c+-Ky0a`A9u~e**e+0@Gv1jCq=!y$+cng{5{EuFN;vy~Gv|Qr^pzWf$f6 z=U?&?%;rzA4H{YPD>i3*_Ft=MUU%TBCPWSYZVx`ESwQWK56NG#$Bl(E3j zz#E}O0L>eR3<3|^wXD{Ma58oW&l}R;!Pt(%QxYB<4;~phiSoR8MBSS}V*wc$d1GA; zbT_lYg))nE{S~4RNU5?CxZWtmW>}dR4T&xENbN=FQ^s+oyIk_$UA|ut`-2n*Q)X45 z_9M}yhxwv(W924IiU4t^jmZ-i0s^*1iA|JLRCsy~uxF_N;2=U_2t@_r!`G80{a$n( z(XvF=v>$i+W=cdV{?paBv&!R&6$d)Tqq(d+SvLE>^lR0dQ?)>B@xDe&nm-qocS(S1+qgix&>gX zNIdWPVCsOc&}=8vl#dZE+W8RY<~@7*wCLy0CMRN?^XY~KXF&$o47`&k1q}F4(w5%d zVm!^{wu!(xH$R_WoW@{i3;nP6jdz!RP@c0~7x^ByoRr?qncTsnGSiapSv%E^*6x4Q zaP%>XTB2u< zB?;7c?lpbAxUBuQw$*=D)JTdh7|+K&r_x92C&ZgdaZsDE^51d&Uy(5MoLF2Fj#rU+ z8mFsD?v|YT(T;Gm^g{x4u#m0}Q%sM^!t*JqzL9au?5b`Co z=MTSst!XgW2@Z8%M(u;~zLJxLoqpduJ1=rAGT#pTA?XDh&?-TN#(Mvb>38m2Vsen< zv_lTnq$s+g*~Cz4f=+H;9M`6jC}p8(ZSD(^)~9*Jo(l@G+bIcab4yqtw^g8b;ck~g zR_nsG&J+9iFj-Z2P|)zrV>;WZr{B`g8pY7gzdHEj^Uy4VZ+%w#0B-zw=_o0uGk>L% zFG&5sJ|}c|c|olb`32^Ct*)7ehO+@x7Kh~HDkezHj~zO6N9h36Qlr?r#H!0aa_+Lu z<3NK0Rj#6@mi#>Y{%uQ@0i}Ih89N8XW;#feRoZ}((C%S6l(Tdf0a5? z;exkE_t*tS#_WhjS=mgD1w=?X>fqpuAAxZ<1H#RkH4A}?TgSY-W?6a7ErlvmhU3+m z)fg4Lxpv~t&SC^jy09CFz{{K_*&LAeSz+N;2z^BheR}o(4bQ*-BhQ~21z#*G4{qKO|bc z5)6o4x-a+gV(I)TXY&sm7+kQb7At#xixf@}wvv5TyUfGhy^ZCb$`$bnGOl2~Dj>w5 zcJM_w4dcNi@R&PoY4caCFkSed<3vK<@JlmdqpZj9xgaz(ZxKV3!ALFB?q6GE zJ{oi?d!Wx9!{B3({VMM!rV3UegfoX^u&aKOL&P()!Pq{79SqD8lqD1NE~t8qEhWRt zjWO-7nVPInC!Yi;3WgB!=?OEwo<2PeM7BfaJsskL!@Ro9=9r8u!@hIjN#k&Eqycz0 zw^ke^#fj|b=&%~IE{!dr8l1)yaj24EQ{8r$sN9ib&@ z{GkT%MhTL@Z{F^gPH`xYyVjO9=sm}1_!ChM>tovqU2-xwv5^TXY#mpF{#gve3kXYc#>R3omPGk`9#4COZ^<0Vm!& zP!kR}#G^$oQxn7rtNXhyp~IX9Ja_WcsVd8?2$+Fb4w&4Oe5x$45|RWGl!0Mkjz?>u z=pVpX0MLNs5yBBuH+2=g4B-~Lzv0}}o6u7lVHNsu)yECA6zYox#yApVjzy<&?86_r#+YH7M%Z&>c47QcvGoCAxzC>`hBOn5 zBIz1*{SF+Slm;f)L6XjHzOC-^_C-Fs-}79M$hr&Lv~vKofQSl?<#(o z>cal*;V2445s42~Mov*taOch)y=K8iqwMEM@RPj(wmZKwXSPAhSi5#@tfmdx1L{sq zfnCbb<7`DMsh^f6>49^_1g&BqtO~XeE+%s7#f00=x;+q`Dq^Sp+xEZRWM}n<=1j@ zP4Ex7waN{-gj^wrH4jMJ?_axxo|bTqR)5zH&EEP;MrlF!DDJPv^O)6y&zI;p?YBm~ zDtu@QADh}`deulSv=vQhu#}x!_mtvc~(RrKCaIE&B5^%hii5+=6j@ z^n2xk8(YIxRmRsHRAZqSaUwAEhmZCJ+VIe01V^{Kn zF;MA>5~?p>Z`l=j?yxzlISHCX8F$+cM9O0uCUFp8+6r%bsOA4xJtLcEr=R@_IILO> zhR&1Z5eUUqR(Q&J9G^wnZ_butK5LeKP7-afGyx%53bFN9mn5yGQ4or`*R-M zEinKY2QWc`dZQa!USBIH#A1R*ewd~Oc4Rk~!24`%GZpi^W|w+v0erslLp_O5;2kyM z%tqJme67KF|1gr`miWCGkx57zw2N=1Hvp&fnN_P+Ersc;S1N7B2tab9qYax2V zA!+lq#Zk|-&OYAlGX3kX_g1)N2Qq$QU)jQ40Y%Af=o#)q}~@fI7*tn zQr3KG-kiF!EoGge_lKJVz+tFX0sg|X8LaMd8(6U6fA>v!VidX`^p8$T6s1!7h2nLlPICR}=5^kt+$D1GAmG+X+tw!=M5)hCn=S;gFSgjtN$puit#@2c}rt<@yUVl$cNqC%qxcNodGxS?%*G zV*f&K!OJ~Ijx5(y?;Vw7Uz=FY!nNgoc5nuM4qMtGgCKg__{6sMdI1`DEO{ zzyKc5qyr!u6T0zsUd|nPb)EEw$$ptXL{z;_bN$r#M#mlH&}t0i?S~C3`G6F3OIf_t z%48Y5?((lK#xp8X54}2pc*86vwimpj5po~LjvYf?6xECHO`@Q5Nl)3UJ#zv>d)5UO z^w_uD9Dizqk^8I`RO2Y}AHua1yy9>K;R%S)BB6=Rvh8ZPe@W1vQVKwu%6;=q4EEqR z_4SS9xP5H{9wXBUYz1wRu;3~C8m%0T~ zaWKZZSs&}vp}Tbc3LfL%zA{eyq~gr^^H<>3>RXTZX~?WL&X=23quZ=@P|)!ptY&45 zZqNi_=0HYIEf3UPMKPHv?Z@EWjkn6&J~yGVrDZXFzLVZaaoeRobe4wnN*V{!rF9Se z=sTy-cY59J%*uV5Tio&M5#tYvbkQzYZkp}yceaGpKCAIv;Mx$aOOeGr8}dqTU3BqV z7f43_qT_p8Yf?Asn5Z6Tui&w7hp)H#-Z4lJa6ch$G~;26X|bOITI+}aEy+fjLJ6+> z4LoTu@jQO=Lb=rD$ks6BLAfSpa~GW7DyY?XMEvlXm6Dw5@V7CKeDn(0SC-fo zvI+;*X?VT8{*sqcHx-wDUB&YX-R$@sHV_L92Y-YBqzhCEL$p zal6l;1p-IgvDe1!@&52?e2rVR13e|CrdQM4T9sjH!e(Xn6*}~{mgu;OK@{5ehbbo< z@VxhY|5=SB+3o4yt{(CN8aS_hNw6%z-d*8IRIWBpNSju)d z6OwSiI9)X2zGpE@Rznq#+~)Xua|7z$I9C-{CxIiR&` zPhivPLSQRz_TIoqOp>ujfqK`STq7WvKF7Gbm-rSaEtG#e+qQjdOXM;1~sZE;uh+=^CH^~sIk{$GH_g&NLR%1j0 z(A%uq2kulI!8TYm^@}eL{o8vBGf-&xpEVd&!#{^9CQy zI{ieCQ@OkR^f&FHq7~Cs;C(hn8osaTk|9k7cBj-*r(WfGB-`3-Rh_&D! zhD>Cn)dPQJDcT+~bHct_R3!VlS6;QL@8l<^b8L9OmAp|%MLm|e2%AUmk$2)8hUirP zJkRM0L1D=@wuPZVUwkpy(R`nm<9o9SWefXO8NbJZc#3N?i-{G%FHdQ{KWT0u`am)I zFCP8~86t-1o; z^nv11WGj|!2Wca-+51)|bqsg9$ z_m+eDdUAKpRD;!tGHu-3`4*y=TUQ&iERWt8)fbxi3}JdmRPRmmf3Q3G9h_haOZJ}| zz=0>M#-f{&j%-=TfBRYs^YThjj-%&<9gWbF@(?HNmsDgK!-|6=IFk;&dZfUwxag(! zB18_bFFS0fc7N&W*_g>?ESB41t+m-z8oCHjAntMOZ}VGmrD4S!4*|OaBtijsZi5bS&jjpI#nYY6J zE6K0LnkbvzJ!Z5>@qO80h1HqsDfBoTiWuzeF%eY=>SVZI7T_e~p*50pI$Z7)S$sjO znP(nLB@z?n-noeFAxNpPc<(P80%r1OZw@w;rokSea=$RY^~nQv;dM=crc{>6X=|%{ zf9g4rsb#aEieh&QARkFa=aXp=8uo?BLz@PSYEQ$5b2@Yq-zEcDVIp`y357-L`ra;= z3zG+h^Wnn>XKD3)r-f%9Z_gI0x7GJV*Y9@TmeW08FJIr#;*8(Gh{hQF(m|=u;8wy} zwcb((GIeTrNfId$j+;-rD+IO-2JP1iOSE4jUu8%BPo}3kE>I?s3)_m6hcWhi zuv5oBFDyj-)YUZ+YdEe+@+)NjxUU+Wn0jcHZ2BYCMp4X+UR) zg0?;{8O1oHFdUNh^+$*g3Yv|hqa#P@(lavL5>1Br&a}j7#nBz3yI24FBOmim7{9?j zKlJ&q15)WKN+l^NZ+#a2VfTj3BhMxQ352V6^a9b@W16? zxP%xfhhMcabvrth2_N4Md_ffakpR@pV$y76q$df;Vk6;!(PPwr5-Ea1_L16$b$ln(lq zEYac;{e|jM0FspNMlP{inrl-8qHEQO;>O~2(Bl$jB57a_c_MkH?Y@0AcO+Hn92ETsU8blI^Fhu{U+g7yyn2^TjeI{Z(l1_Sj{IsqAKR_E`J3sk8t$iOIgC=~K4 z7w&S8-Zw!=a|}Jt+GF97=3`hYRad<&Ta0l~;r@c_F$kgORbntcBmDSb7q?N`R+Et? zPDxq8EWt9w$YR`!r--c+SCY|HqR)v05(fjW4HsC^tpKgzroZUIogwd-xE#R|xoOi_ zrBkL&<2`>)87K7^WxTJY>xW>Hwts@@d`Zt+D-D}aB+6VQ@6K~LMpzoL!zR#|B`E)L@&QHbrSShURf+T>!+W%u+=m* zXF*7>==jZT%fqqoLDAk}<6jJWozpvgWEx#qNjaeK{lA&=L%@c%z_4aGTVKAk3`vGe z#Ufet(5;SWrm{q*uOLT|GE-q~0i(Nm}zZIFkVFBk_ z@Js~dY3ycdlOQ)V!s1ni8)YB47jHYf>gd!dhe8qiFq^+mGZ~*`g}rvW1^dVTpBLYA z&eNQu78_8NY;WDls>7yB&8q)pV)~{+K7P2yGjnC!=IS0%Zs1zmpidaup$)(P9McGs&>BzJL^}YQH<$_-@Ka@72R4v?0-La^x~+qV`+hk#sG&+n5(Q>p0&Ik zvnA)!Ib=C>_Myk%N+ux5Vx%X8x&^9FOa|VjEU%K?DtUTc_tar z^;Q-}hDUYUv%HgPYBDZ5e%8+CroX;!@hxM;H!9}4Oo4`ITO|q+Xz&UgT@WR{#&Sf8 zLl<-}Claa!mIFwDX3FwYgN7hK^15?1G|UG-#fMn>z=WxH} zRQjaN>$K~@+T+K(9te55^3mnE5?;<00R^I}n9$AD9i9^2H9^27CY`w}lHo(Txr@MY?b*~word^K>9Sfa9+awlcuC%f-9 zQVI*<=LII?80>&&k6sI3g=3~P7k)N`*h}%-g&CfYW$$2&S_O6~g3^eqAj=-;UJKZ@ z6!SJxQ&Q|;EJ|~J;|H1?t056*TZr3gs$T^MsSa)e=ulr}eQ$2oZyfZAt27m2E_znV zcHt=rToRIxXyu@Ew6>Moie)-^b(W^BhhNY1UR(2nv}~;o<6Q2-l(}age~+GEcCEEr zj*Qjh8&4$t>#|(!=F4WE$ksEtiQ{uJ0#C(Nq#+}fCu24%2FIV{u#PKXJ_GJ#qXX*# zVg+MM0incKN}CZDtFaiQP_lW%<~N&4xv+Puge_k$OV)Ak1* zQ~TzbIESls!g$4eJWCuHN9yeTF{+!_b)7s@SZHV+eP%I7kNdI+A+T7RdUo)KrD{J0 z4D;mFAAm%;htn4Pi@vff)QT8qwS(i=U4OT-7e2qXwrXUalnlD?v!MHFzfA} z*Q}f0GdBD?Kr~&q==0O)pY=Eep)M_hhm7~)KEcv=(bCd#uUg15FNrH)4?IDIMeG@M zx5OfQW2W+a<&r#~{y!NEabpIG^)_lNm$o^dIr}#2Zp10xD1*uGzECyy357c?{q?Ey zn&z**223s`tr|^AMI#&243=TCIH(#sv_TSd*2IF4OldPH3Bu@NboVX!WZw_JnKJ7^ zKzD1*fY1ArI$gU2y5Z;d1e6EUyC&-=S$;D6-svM-6pQV7nR5*cK0TxmQK$%x!X|P& zWO}93Rzm@9>g8u-Chw6RyhB)u;d?4Z_fHO0MQMERRiP$t7HtkzGbya?uNURIvCx3e zhAUUAuVWo11ei(RzkAn(_0>c}GfFbCdhj_Q?eOrM32$M% zLIh4wYea&f2;!pnrAuKG8K72_vG+DD_e`J`)$XapO~wG8aJV~FG%LVgs%V+VW39H2 zGaUDDVoR~P=egBZpUPB$xaVV=q4pF>Q8a_wNj*UpAF*??pW_V~r5OWj&2+Dy$SetQ z%8YSqtum8h4uc~Jmk8qA^X_l9;oa$Ya*UnDO)(8go}90(2$-@^9ZnPMPAJdmhatyOMxa8q3d|W?KB5I zymlM(Z@@?x-I?y|>%66WFf|R4pO1RjyJ^bV$G^9H@0%8T=g!8#nh<5h_9vpsjD&7Y}|Du4uF?}ra_k-`M^z;-iZ#ByDE3>!tK5dLVrfLANJ?Zzq>aWAHitDV_4 zL_{*e3pzSG@49P^XZ)r-(y-$N{}yhYelf!hVXFx6u_SPjgAYangIB#sbK-g#m)_nC z8~@=weq($!(2flKzzg^Ki@HO`J|w`((H&yUMC9j%2owuZjWCuZciN6`8D)z`@Y};D zpzz2Ly!q;nYdBpGN6R)s)`u`fvs*~{WR|E19z?+K1E~_D1=do^67hjhGY!THnUS!^ zox|_ynb5@YP)#_f#PC!{U?2yM)-fQdslvvGzr6P7Iz_K8lz?C484vR-heZZo$sQzT z$=8li2NBTXxWFyL9mqh?@I;|I6X8@suZbv~K2`E9*H;j$ivMN7=wM$QaS}UPsO3CH z*^G}LX#=RuG8jU07*~@VL2BcatLjvHI1D)b*HFa!Gxr=*&@@9WYy2Po;m({;na1XU+H$DEKLRn&3!^LM7`>T3tTN#) zIxg-VD<9}0I%nm1nC8=D=Onb87s$2Lnfq&MDqn|vD95q+amj0}Y%Co0W3u9p4-@0i zrB1uDjjReMp{#8|V5LuI$-a!9o`rdu6F#%!={~75X=c}M`U7~UJX`8~q?B0fMc1Y) ztlV#!XlbP!FrmM{9|j&)>6M@$+g8@bk0auILk#ZtOp_5+Bvid_n^9)M4_?kMN$r>R zRA3u&3Q2}8s|P8MWl%kCt`@yk=GA_ZY@9GbKYXo)Mue_io5m00;9}Tnp*aAph>H(MaqAQFbG7fHJC7hslrytsF$9y9DqniLB~gI*mmet!DOs|tB{PlrkJ z?Ur?R#+Hkb*ZhJuFW486fG?$?P=F9s8=r|Mtx*x3dv~H7TOKe5Hq^~1qi$>W(Q^lB zpt{>h)-K;C+4yL|&l7vNodPQeS(iiVshBOj;vCx zzJI=i9IEJxxY$N5q$rLwu!~0Ffb_($8pMwU509LCtESX}=b~05wl>|Xbqw~kO5@DRG>TI1Jf7g%GFNDs6n*Hp) zz2|{Q4s<-UE>LZ_y{5?H(lz8?XL`0QYQFnyF9&Ft>K>M84Bi&3{THwR#M2cO6_F(0 zL{1=dpUI9jvEUN*Ik?92nI0g09o8B%$yJ7>;yk)7_U(MDfom8>x!BeJY*769BW$+N zLQ%j!b8lz?GaR|U|2|1h-lpVH)U<52H~$jfCOk4G8; zh0Y}~X!6&vknSM+2Ta8v3A58=4|)X-L7lnWi!A5@JT5n7L;T0B-alMCdopJE?3ZSG zNtKwO>N82pdaDj;j}wW0fmKZ?A6-Br`EOyC0!PIgHG14!WLIFvT4vEFQ}n0k!*Avo z{q}p5zOw2foOH6;U$f;#$*|4ISCY5UZ9Oh#XLq-1LO;563gMUO2@c~_lIC{Ys936R zpyz1N8l|1-aspOk&SD8mkZ~KTcE!flGBy{AjbY9NsEcq<+-jlRTP z$Dv7WOvOs)`i)5q{AXUfSi1v^yY~-Y>xbe`&8Pjc?be0^aLSR5${UZLg-MD=ZcdIa z&9j90=Qc?tRWlV7l$lkjF1FWRV}s<|7Yb84g&B)ft(*_e5+zNqvHd9nQXzdgdbbq& z>5@Io*f%Wyi3yXE8`9YH`0O>Q7T zxx5=AK`5v~&m3L%)qSsIIgxl4DMOBEUYuJiOsRaLAN_5oQ}e$daVgmN_W6}ZSO zw|diLvEDw7%;QcE>bH$fN&s=rX;QmYJvq~}WE>SR@@CSA* zYT-eCpyFIs!pxl(BsgQ6xhees6;PDqoyz-k!md(Z=rq2?dUi8dx&-s{*EY?p`Tg*%4)?~8T7%H?UmPX-em2?&NG~Z}*H#go}@Z?t_bqgR>|% zx9$IUfXm+LJvY57>NMyC%Ry1s83G|Nx&J}QgXLO6AWX7KvQnBJ-}dJ}YLe*O3LfP) z=%%PRnh+5Q;nJ-FL%F#~cKJYb^>evTEv+zWeSNCzl;9n!v>}lv#rj&cE!01K8g?e2SoCNJ z1cF4F$sI*jR`%=%9Rn09_b!HrC^nO~7lBY5p)iw`&HjMP2Zd_zqf-(Qu~G#@fCiCL z^0KmF-T#G;i`C=M6-3s#6F|=xT|%NDGt`JU;^&z4{h1984t{GJ=&bw{1ug0^Ud`(z z2%FE0XfV>=D@^(f{aT`ieHf~_xl^LdmtlH{Tj`MB+M@P>a&I?JZ|@Fx;`%+*Ma=D| zA-3+<5RAPA-*6LovMye}3eg6E#}uYD1sRY8doI7;dM0-!GZ|rdd2PARU!)RGvrMuW zrLcXlHO#mb)6)FDF1C_tu}Jp3uA+<0R+9hZUE)YJsQc{*2o>C+0<8><)Ea_(D*A5~)# z5%f6@aq_6+>1oewnqpBL8D!G@dpC~8GD(T0GYSfn5BOeYY8TQgX*6FG3030e{Ijrp zcJMkhknkyI;pax&_z&Oqt>!SYxl&OG2r@FBFEaC0$IM&_Xn!>8pfJtZX~b)U)DYtv)UCO~=;M)5e;V++E}9VC)KE`62ht-X$$t1BLVJV>C)- zWvYC>3Rm%J#R<9GXWz67IY;-?B;dojuW0M)>!soti*zfyp-7E+rD)%gk2mfrX3S4w zV^u;UBfHAq^{5#b6xsLp_je@mzFXSd3^DKjB9%2lCn~Df%@*1lM`31mqM@M?lb#;k z*(n=A`Aq)63DMi`VHInWrd{|D;^8Sccq|Cj?_uDputY&Ysq;aKLX6w|P_En-B$dp> zK>Od4S6d8VPN?iUC7pBi&O{_6jP6RZW+u3xiKC-q@6b@s&jfZ}k0ayG?(Uz4#6-Fj zJ^#x&h>8^;GB-DW%El(GrA4~8zdur>`z-zmtLx4fYn~>X%l=F?N+BbZk0xM1KHk~Nzs!dN35!+YHT0J#mB1~85ylQk&=?uIjv)t7}Wb4HoARx-JPHi_uvV}rF@{E zpn!BDkS@y1d;lqPKQsb|RhKk{mZ5)eP)=Ia8Vd_cmF+Cq@$vCfR@NU?mcQwg zh$a87J*w|75=vDK0Rv*7r$-TUKj6pYg~Q=4J7ZYt>grpQrL<5ebZK|jy39va6<^S1 z%1^|3W2rp|2T~C7MphQh$m_VP`}#WqvD20l-8(uu%HwtE@S$3-uC9(wSePO?Ir;K( zHQI6gCn;ER49IXZ-2Ed?ac+CNG{@T(1KQ`1rL8SQQW6DNawr{L+m^>0OH0;Y-$Vky z6qm>HUqcRPM+Vbjw9W8~?&H-SJZTO|$pyYrE6eBbi-Y0`LGzy^FO&KH8L=)$KOEW% zs`ovJ%C|r4+2Kqq7+j3M#E=cDmM?|*L{}!BnB~Rf-4pYc0S+0*a|?@{7Tc*Z6AGA*I6sw2 z@vap=m8`rxl#h>?l9KZB=48lmdz1;2-r@4d1nH!V#anPNKcs3rc6d{M!`*y*@;#+4 z8F}PwUn)uNKZQx#bgYgo6G1X)@rn~n_7Ug;#69{KF2e!>UWlTi;`29eDA?H9i3kZH z?(XiC>;iAWvXF5Z3M(~7;SKpzn10> z&&LIyI^kJ{<9P~ixUnC`f-e(w$g6eZzOTRev=udd1u4xohthj;R8od3%wKTmRrPN1 zHG7^tfCL5wQC7Webi;cEL-K=F8E*RM{PHV5R;~S_-O<;XDouZ!WglV#O+}& zqLR;(KMyho*sOL(4sW|82|Gd!3=Jc>R`>RB+jx4z!oqlr+aP9UX2#%wH}y_T;1KXS zttoC5?b+6_sD2xc#t;z`TOAZyl-->u9y~Za#u1yTw$4qzDD_45FUciji{oggJ)a4h zeIv?F%zjH1wD7(7cq44JF3E__-BR|vfG z7_arlQV7{mx7_@BK`rS;p^`PN?UImeB|Pb*w`O356u#=C_Y(KG8_QB4jV>rE z>iiLafkJ_+9>Suc=8Q>ayhrq7en8C5!P#Po5a<2d~Wt3k#2VD3d^< zXkk%va|V#-AWn)uAsM@+_kJWz;cz$kO&Y=R+z%JJTD-4$OxgpfdKMm_qB(9SwPO7FPMyz#s!whFsA0n+^f{OliFhnjGV=$7h_L&?x9Kx*-sYMwj8TcN zuw+IWx9(1U9i)Q2nQEN%^>sy6)$ZZ%GLh#A$;qLO?uTEsda?@qJt+T@o-31Y zeT#J@avU5S@*It%q)@e9S#wyC-o+Wl16Tlnv6I{~ar?YS}PKVWQJW$@~`1wgv#oXo1%ostGXSC|<9KSeB5wefExw)}I&VwS6mPRHy z^e)GGvSj-Xxn()hz{k}2WNY|4Dr9M)8ICSw6n_@aXguhDt5(SPGOhNNZ$2`l@D;=Q z04GNnfdU4smgQ91Y~F^i7xWnO?OOy9gM3?GAJ+Ev_R;BS=VrQZl^VvByi-j^s_T2B*p;lt>k&~6>OolEd)x{lVo;hMuJ6@Sbj6D0e^B>tUQ zwFvy2BajfpNRb=s-_z~i<)&TO5lhoYc}}VJIN%N<>5Wsco8oKg&$GN zL!lLTDhCKaJ#29P(*&d_oRL!X?m{lc4An)nW4p(9Qr5yWCf3!_jqe*5TU;)Fg|PbN z)Zyr~ZklxO27mo~PPR{a#obfo?>HwGezPCXC=!+`r(p^{p@wrO>Bu`oWQ$;*aZ~R%`%QE5xi%7S}yimx7Fx`cQlXLTf=|WpM0khC;T_@NHveT%|pRL`J5mSAg1w30jzyCh$n(=(SU#6rNOZu;{W@o`+s62SQ3-TfxcA|0=ar8XNCRBS{4# z{Q8=njFc7dp?3g{7sajZp`9%*pqCg09JHBi;nO^KG}tWr!9 z)fYo69W&g02oT;v&1xpB2Cdz7t^kf@qlcZ#B$_m;pOW~9c6eXuSHZ#CW5-Pp(_Hgk z@$xE;oL_&Gm6z3)``{cAlB9>1{|?^P^-%42e^mPwi(ecuf_>7jfUQHPGl|efbNs=3p>qPg(OP7+rBc+=v!| zCQJs`Me!iYNodpV!*t}M#x;b2{WF9NlMj$u=&s405wC(mxJ&ct)>mjYxCn;8XK??4(cH{k$4Yh0lm z5kSxo6lay<|E_y{m5o{7*nk51lq%}#A0Pi{rp7k> z^3vn;=g-D7RhD1@(!KtK&Y2Sv#ZuZx-g6{EDylH17hj$ijza-Q0=({?Bk`KFqkV(< zKKVCCVuFTGHM*DnKn*}K{`r}eP@2CF-n)=Kjk7Ywf5Tc*Ir0}yeCPM)-D|?p{ErMe z79xT)X7%;;6arQxReGEjgI|M+ia4@!a-<8#O^;W)?wKSY(17(dxb8B$*UQS1T^zh; zakv_#;kbKYUv)f6F#tcSC+w8JTuL3%a6ETPdr3Nxu7WW=ko+t*Hue+cGYjMG(SIDA z;g2~t z{ni>O7s|q0RZ43_G5e4$A<*^kB7_koese!WHFpo=>8wqR?OYv^Xe$0A7S+JQ!om^r zZ>gyOP)`F4at!D}8-S`rL`0Dq>_qA^`elF6M!Dv?M|ET098W$y#kY+V(xL9@I(<<8 zqEHA74OB5y9xvODRX#pG2teg`x5(Ipgdk9aO@}k2@bnpp)EV-NNbV`jH|lW@OKHNm z*VUI>;m@2B&4~oBPp>f!X{{zpQb+zKBqRuX9MJ(<@j9O)eSdj*`HK9yZ#fy(j7_fN zZf02tG!7kGJuI8$_ZciF&JMCplMVqjs;Q#OCBuE1v0g4^7~-3{RYU$O@H%)YHvYMl z&8rra7p-x{&c<|_c|4*+QgKJt(H{b8e0Y%#NIMb8{Y?J_${PhAn=vslLHsHz__9uf zY-a)iSpW*mckk){{GL;3Te@Yuzn0~lrHT4DH zZ70J7@rQj%P7sb8>D}?euC^aWkXVIEX(e8{1D~BW-Omi=i|;$ks%$e!$z|<^BEn3?wX6 zxp?Ak9uNns-^#`~FjR@;#DI6zf^Xk0GQ(xR{68Y*rlw{!pGnl`NJ$o3!CrJcs=)gQ z10jE}jsX6H0%2uk^|<}J84K7+hNE4e;Dy7q2ANL-N>CTm(eb&IyuAE>UxAk&oYh2- zqyaVkiQFHQp(9WnN-7{juTE z_WJk>I$Q5@3^m|Cm){Hx!`6)Q{*|%+{11v^%h_F~eI+@Zk&!V&E}X2+aTQ%!TKYZ* z{7MyL00B=U>eANs2^EDRDw>FBno8-x1jiOZwQ@T+OQ(r5zI9jp8o%b+GcO%nj-27r z+!KQq0Ruxr1buyd6uhQr-@bi|NlU|j_3D)unB@IA2gn}N59G8O+le)`)BWY3TG)%O zAZr5d>d9@ioTh48H!D)@X7blB2quPr0P*0tni?ShuLafQ2 z-GKW-sRg9r=e1Wj0fO^Fi!vAU+8KsoigqP_jD4Ck}CU0u(wT%YS8r3thapN89p zfqmDOvzo^)AkTSzQ7RDp%;iDdmtWQtwtiMKjEW1zoRjHYo&Zu4p5-m8HS@?F@a3W8 z<*4|3o??cd_c8E6E0lNCJLvy<%GAPXWt9t#`)idbscGot&I8$MV46e{oC^}5mKJ>} z&>_h4JZlRZU(CqMAhfe0HTq*8`s%l{nt|>^9WenT{IWS#wh9iVER?T80VGs5>tLyXqt%YVWY8o1#xcPzF(GTQb0d-tH_A;Ony-XD)g`e;J0HleC zh9)wWL1AU-M}SkJ#TXE-c|1=);L=J`TUuIrT+F-kx*r(aoTT4u zgCDR>0J|XsZ)0ddp6j3P&+6n9Sk-v_bppnV@kpi|#4jU*?wbUhjMnQ21xTuL$%PD= zIl)pEK`x>+*f==LD=Vg>p3;~GNKPCr(Nrn8xmLpMVfZ9pfeP&BycX)Ac3QRFCKyzb zpzT+w*)o%kG9V`d{j6z zQ_+Sv)lIKGWjRtw00lPa%=Z5On{2 z+)7cikQ)i#3sA zKBFNb`UKQNI#yOJ6B84U>;2l}+v~%VQ8+a2VX0o#18IaPH+)~7?50Wo$HHx2tEjsW zc_&`vkHp18KGCGRvlKsYrR?%sd2-HujQ zdnErs7Ur`1gvk9h+!@os?3++tXy2(*-G(8^X`k3Rqwwf zK%YH(M6Q}^T3XB9jTb5lHo>eQj%xHCjtx8;S^`5G-}r}SI=YJCI@V`{u;p?Er>?QF zUyWWDH7Zsj6WC8+?|NeBWrl$wAuKA|4&0KCV7!jjJEXlP@*2w=tl)&V~x-&Lf-5Vzuvjf0~T93o!JQO3Qw`bYTq_?S320jjwjL$JFD zaw88EIXStC@r$Jo1B;V5si-qaO+LA9w!=bA?2HgFhW5UZAAjWZhWDl`9f4jY$_c+d zw-rAbcs49?{((z_iyo~ziY6SKig8N-D@dBoXRPrINOjqjlAQkeg!fp;?%S;;70|Og z{7_I&Pr$K=O-e!lA`zeNiwR+$@Cnac;j6TMB%P6$O#;bqbn{Q0sY*$u-OtUeAjUsG zx0oEI_^JG&>~c^?P2F)Q`z)tP93wSA`f(nc)k_^8iEu4;vgE3$)Mkkdj!OzEom%vQ zFsite!e>Uw;@w5ABJ$`oR}JQ8Qo} zJzDX{^FrNcvdZs+O%MJ}&l(}BUjW=EP)C3F$wgL!NZDpC3-@W#&oJzpiaQu$4_1f5 z2DR>{LoGA!CxcvYv-*m6a{L$^pWbujbmh-stgW>FT5aUEVejBBfJ7u0y;9w1xnBgg|37|-CefikYG_HQ+F>1 zuV4;|t(aucSjV-B5qE}jSywky$p|G?#^GAKrf;`;|B~e56Ei{zosN+aZPDl2HkJEA zFhOL~CuL=73bh%URel{(s-~G_KkCVg8sg~HDc^}p9lYAQCum7SF616~aeyHv=2OI~ z?%mz%@mInR5S$DEx5{d374-C|`~w2kx$>2wA|`s|0>AIJq#wGjRJ|3a$xA!ukK8_aH{=2l(Uav zA;rLml21*)T?D>u(c9LRPwbi9HJ)cypj?)!_P3mlzG$Lvz*;4m_9Z1FGX)(2mdXvu zP)QLyIy;jCI3IW@;AX+UC3N)CfAVP~CFla%Skk@x2_!Eez!4nZ5EB!72T1Lk1{YR- zs$Jhp-ee$O<2r8){3y^WjPQv)JwLx!LJ4VU7tQX{2?GY61G9Ca#4!A9ckyDtz@_j62xW2Y#47|hpKQ*}Rhas=i zZ`$rlIxdYU2`CtA%^$S=t|8+X0TE_e1_lw9zjI80BwXjRP3-0EU2gp2LHyNyQM$L% z4H{gq3Ux}mK_w0cHksaJd2MYESgJB0mtTE;Mb_r+x1&NR;P=+&uiQP(0EUK2U~q64 zcnyW&L1AeNu}ld5_^WgYxHd3>yR&WU>*^3dDL}f&$_7r=JLmTH^$`IR`%wr!4Y4%l z@!90taJ%`2(9uy1WW{8OAuyw!Fxy7&1Ybi0$XX8lI1T`bL4=2Q09%si(IZsgB?E|& z)qi_FYySaIVINUCI*6{WZeCH5tgbGlsi|p1$tF;Q(|xY)JwGdj=~WL#YM!N!NQwY7PkDY$lc`vGtfVYYsF7!9n4o!sBQe=o1D zqJk(SAtjYKp7j9sgz@|L7{%I!ck*d~OaUJbSpj^;=Y`tEz_*ADMw;|;fcGz~N!BXW zY=SAb&(7-aEw;YJq?gswN~rU`t{E}M!NHLO4LbjxYz7fZH{JZ{H=QWbWwy2dv(~qg z>b^iEjp=y0rM|qo%YHE5$P!3+k2Y2Sz-aFM^@|Kx@Z=cy)I4tzR~hgE!16MqQwku! zZiNCRjEIVg4M-%NU{=-!=hug=oT>tC-gGV`rK-kfdgQm7NRaH=6pfM=Od|I-RkzkPbms!BIq1Al3|KeLh aNN#Z+y9!AqPcv}I3Zf*ZDqA9L?EfFtaa*ha literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_11_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_11_0.png new file mode 100644 index 0000000000000000000000000000000000000000..ac133e523410ad67c1deed4d09ff2315258fc361 GIT binary patch literal 7004 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 WcK8c_0uH($5V)MGY^k(Sz`p^pu|r${ literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_12_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_12_0.png new file mode 100644 index 0000000000000000000000000000000000000000..94435917b970f30314b7017a1f7ac2cc20d1cdc7 GIT binary patch literal 6991 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_13_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_13_0.png new file mode 100644 index 0000000000000000000000000000000000000000..cea5147eb1c751ad69fc214058cfc0ce6d4b7f97 GIT binary patch literal 7246 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

ZbTXc1f)Sgq`PD7XX*d_ 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_3_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_3_0.png new file mode 100644 index 0000000000000000000000000000000000000000..ec9c1acfb6471b0872ace29461f6adfd8a9e3149 GIT binary patch literal 21200 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_4_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_4_0.png new file mode 100644 index 0000000000000000000000000000000000000000..ec9c1acfb6471b0872ace29461f6adfd8a9e3149 GIT binary patch literal 21200 zcmd6P1yq)6y7o&5NFyL6Eh-=-N|&U9bP7l+DBYckf*>FUC@G+%fQWR1fQpoqbV+?k zr{sUX&a63S=FFaR&id!fIeV?W_TFyzzBiudzOVa==b?t05(yzaA%Y+zSFgxxAqbWZ zf?)F#;K82^Fh9Ks{}6RkFmTg$v~u$_ce#bAn!7pKIl9^1v0(AI<>GqB(Ls<`l=s4U zmfLP_POf5neD;6&0bWNJYd%&roB{Zd<4#wuyCMjgIr=wNmUQMF1ksYbDt}qWD{*ne z+gPW+Uiz@(madG36CGBJY~3q1$XVFZJl35yal^uvsEBpg*sjuM$;&_C*LWCq+WgfCimMGW9BfZQ zf|cb@AIEtfcI5;f7e&nJf8h^)Z0)6F!JH2nAlCFaHQ9)CxW-94gQaVM7yQUQKJQT8Z`_Vl7jzgq6{bfF4Jtm{08cPg>9mm#FH|BVY zZSlA?i9*QvYoFtRc%aFkkUm_0CTHBB_&h@;!}_oKaY0Yd4kYb_~R)Z67_ix1l1V^=j=&$|utG z*}bnXur795QeUXTrPOx_Hqba5%Hnc4oq2%;b)2U6`k_ zBuQvbpeWH{z$pAuja2`3ZAWtDe9!}{A+hkdefg~y*ZP=!KVJ|0IaW3ikzm_$ht$(9=^K(p~m9`DqcPzP_F}`M5i7 zzQ#j`r=LDu(b3bxMzplGdtGXF_uA`aI4V>RcUq(;)1##t28(SA?FKGyf-RBif#KX_IFlk#Xa8UX39TtCi}Z<_A}4o_d*=Xvug5Jt`O|+?~^k# zN5`4?99L{*FeEQ$#p5bZ(#_SImpHQH3-{jka!a?mbY9J!FumNSRJl+MJ-r9MOXc_}frp~8yf-kIJ0~th1S>mCZ`U44 zhLFDyv?jIcNY0B@Qc|)Usc=Vvq>p}ehg){iUZ1(FNmaFr$<0sBQ0`MXyMV#Gvuq(n>N*0p1QT`zESp(`gib1^Q~dh% zORM?ykoB*4IT0+w5WJ86FxAN86ZF{--UJ`mKus0yNvW$szZ&k{j zE{wTsu-bas&wJ;T%c$6716>I-PH&`fnG=@u{sfshKkd8QU2KV>u6U;Yo7BX3IEO2t z(q=;?_99N>2$e$pV^%q1$s0&rf@96Y$w`aX85xs3+1iVkg`L$YB5M)}cnepqT#?b%retGhr=X>sYj`>O&Zd{^YoaKnSQ2S=cDB7?@1X1I z3x!U%0urR??Xd2w*A6MKekA+xDH;(bq5aRfBId z%qwY<*45QDsPPkRj${bU$>D;#Ps_>qlD(R5QcZ}gtgaRgHN#s#cII@>_Vt|Rhvz;w zx$w~RX0!RSKHk3bfu_E?3SrIAvxM(u&g@^U1T)lAqJn~gtcKhc2dRVHU-k9&vR=AG z4I3E!fqdigyVl9xc=Pk~J3os$#wRBBJHB?ME0vDUoixllDQNYzE?Ls|lvIgI952#2 z*|^uAe*?#9%5@^^_3P7{s>w#$iB8hkl8$~6*ODdZLg_Jy^reD=jSK_3z213 z7wcPwD33;c>EDl?5IQ4tlIivbqob7IMkn<+2I1ypugT+nZu7fr^66dUP?*#rTV>oS zD?Jvm%?_FyOTW$M9~n+1;J7ai7I!XeelM~nV`F1Okco*2T2YtNYwPO*x4uwi&QdWm zk4@UFTJ`q!Vy0_~me&VjTYr_<5qT$OkPR%yxWzlSFw7aV4V#xXrEP2{$R6kE>f|3rsNAx z?w(1t59`;0h@?JGUcoA7MT@}N{dt+!q-0I+kHo`xD!EsCGdOpKmK8034hO0*q&wce z9l@9a|C^x;nTyMO~9FCU+h05d@-1bEEM%*K@-B=}@Z zAHyiv?FRjJ=QEL@z2(}mY=Kkd&usTsr|L?D52Z`&2C$=jlZe*Z-%boE;y&_HQa0U| z$DMp*de;0XW__n|jI`12q`~2A!OFLSr>m_gq#sj+KK+X4kq$ToJ22PK99Yd@}jO%Nul+hic9_T6^aHgNOhiD!()58bR^x2=)A-V~|y`m0rNOUe)q zpE}w8qG!|?f%{qX621y{u$(@Po2j1C{Oa;Ov?0EDK}*ambxKoHlUCT_6f&fg;j=Lp z4BK{KLtk5aYNLRw{mYkznYM(kT>S#QArGhq9nwb<_&!T)gSF zYeTf6>vEL^55Aaq(tdgD{%uS1MzHXk;VZ_*r%D_~Y_v^GP08}~h{(vuh?yk5=kQ8O zGPcI@+*8YxgNs7U#%laUyw^@cD|BeB5^rcElZM_A@V&R2#f3mWE2$0;5=)58wQG;s zFh6Idk3@I379&1CJ!=X3`+JqQV8Ghb6tkU`i7IC~w*&zV@nCkP{92rjytqAtoR&81 zMx{rp<5%(y8UyS<;JV7+H>vA7@($$4Q*$=wO zc)b0F)SM&tUO#G;;dtN3E=n=;lp51Ab60&LW>xN7eft67Lc6l&vy*`nH>}x0f;f+2 z$MOdSap#!3_OVDU;0h*I#|d7H?X^VSRf+5R@Z*@*{y7q+&ktpymx7+wPCR#DXAR=k zXZ;e@Smi4Gk!CM1N0RB3`8s!F(i?)V%auj)Nr~jxsz+m5;~BbKBjyrRUe)hUe38_2 zsd)O0sEhH6CY6`u9x?e~f3J3G)Oc#$diMQq4OC{YP844`e*8gy_$*zHXZ&(QkLBB8 zQ=>MOfHWa;MfQ*SP5gmd93Kzw)jbDPbwc!Vx$wy^_t^876SjzB#-wqcXDuFXY~g3+ z9-SPi*qQu%H61Cc%Vl0v7L$|o%MO??fc zBOc_~7tbNYz4=U!NjagHkL+#Z^}adcP6ms@&v)JUa>%tS)c7NdXA5WC#y*X zz^i_S*4JIW=NG>QNA}yd^7i&T7wJiSHZgBvQzX1kxVyU(5E03BBunN+-N{~Z$mq2x zbQlra?>O2gTdG`^+S%EW(WH_%+?mQxrq_(9GL{S$SJ2g^#v`T;qF`4vcuqq@gM&OE zWwddaJgLLAR=yh-DcM@w;w5$R^db@yPhCqC zq3G)Bf(jd&lEMt2>TyyMNqX09*GG!!!N1Y#IWDe-uP+5DPM*XI3=AY@6r)`GBti#&1N`UNHmdU_|<*4AJ$aDrwA?f-RVCJxeF?j4*xOo^yLF2rib*n@LnXGZyPL8u^0^g^7ZMT+sjCeRG97U(djSwo*rLuU?+v{g;B) zvYFi|#5K(8>(yp+d8p>9je!~TQ%8r=<;z%HTwEIZ`uIfy#N&!(u(IJP1Yfcrym&4C z;^z$MR;ioYOCxz-TEBc*X=ZS&1E}ro?XBlOXz2*wBEBD$%#G;i=#2N*9$xZT9wp)9 zuK0STEtV{&y z*Y}F8T!azQzQoiwxWsi<4UsW4G)$Q3hZpRj*&;!h{X*19oJQShGoz;4C3x zRO-+K>+h{z51GUYl9raX0(3(Ox5oPVIt3lwfQ>jzm#{^U{sO|`&C7n)eADOkYGOkN zckwoQH*`zo;FMc} zt*vGlhU_uO_?PG0_VMY}&-2rTUnffHkNd~~RR1*d;_^MbRKQNEvt3L+)h5-A(y)Zz zn%0{5W8a-~nCuH4?CeCkJ@>R>e-~$)7TY|p_~v$6gN#{#?8+8ot3{W1OHrLFo_k5`*mA+(c*95@i$>@nAg>@bQ(_uCQXr z9T>BMgM%^2J>k^cJ#_-`;6Hz^ckPhO3|JRCk+pUAIC9~_g`QQ9pWn@OGy4|`U8a?v z#l_{`+Pd4_MV(VLJE*CprM2>jJ=(zD@_Uibrp?V;x6HdUREf1KD$94DAIrO5WEHtf zm@4JJ8wSHB1r^n4m|>b=C*RM^%+#P#Fs|{tF4?@MoRyQ4W3`tk9aw{~xVXC7W8g2S zF==8M@ESjV{>&yOW_T`~4a$?ezkl_h)aldm2)S5Ndk*uT_lqn+SEZ+8q0@wHf^)!5 zBXc-3wTpYAPSz;_yV(TCk82*m?5vBB*VNSLO~aqf+ov#?aw_mR?@fQadyEKO|In78 zz{0e|25=J|;e!FY2cK`sy18A%#=*fdt`!9u>fYnW& z+!G1d7vVLnA&ykM$ElrRhUv-1{-tFD7vy*psFIN2pT$W!mEelV%Zt|K>CCj_(YJ^)hj`Gnxtyvsw7)+qtpo^Jzg0N$=dcYbb zI$1nDtM0M65w=86+#@byX2t>&#Qhroy~!5oLxGu&l;{|CB?|z_i$2e(C`6kVw>7fu z)6&xm-52!q)$h&aH%}A&YpLje84Lb|fR&tz3RgkX>2TjWcdf2Y2JjaV4e$3;mIYB^ zV$6Vmo@F5{euGmw>gcf z?NMKzs5?Rlh2HB{*Ir&YmYSNnvbm`MU=F3rdUN%SBI)Spjw@&ascY36`WGOlwR@bH zIHa_+bYvHXJz8XCv)@#OF8T^r*VV5{;`#{r;o%|MnKO!~&z_9{f{_Tp4tgQxo}=q~ zubu@7gEtzJkiZQ$q_8|%t)Qj#gn*P(FM6oP-?wNgNzzvj3USsVfVz(>6O9VcVGx!I zk43Kd`1lZVS>q}%O@th7vEk;0Y=2-UvRrG*e{beuc7yh6=p?-*@D|xvSuaC*^xUZu zvilC-IX*s4%A708ZE}O}q;)N?UR6a+(}fCg_jqbd$Z<*y1B0-N3b9i_nE;<13Pg4= z4t{5*I_&Lwd=Zx)VS}SCqW+s0U8t$7e0*eh_ptCuPX(D2C;mHSyn_K;B zCgB_}uOeU@s4cyzmiB`mjwAd)IFK@iexieSEGQ@#^Ww#AS8HKT&f~vHms8>%*LX^C zZ7eO>;SPhoe!aH&9V7s=`n$)FeCZ{(T!n~}sqfyArz=J_L@|o<-~2?Ly9-@z;@50S zDcwR}wTAV!I-{h%zEQCawN-oKacH$Bqt#QQishnt5q0c9S@5YwlvS zDh%T!K$M?5cTPq@;TUuUGob{mVFDUpe2S|%-essJJh=Mw%)o~AKqzP@mAc-5XGXoI zNOpF2+4%T6a@2i)F5VaO4IS%p?VWc+aRsamO=Dx?^saOE>e`vz#n~fk)2*q{+-&=K zQKt6QD};iALTd&w4z%)|`T7zGGCjcP16BE2`vAtAdNY0z$>>L->h;nrb4I`g%DzB|*%j)t20&Ee3Atd}oewv`kQ_xvZo54v<6 z3}0lhj2l~8@KbX}VP73sF;T_c|XPeCKNqM{-PZwzRoP`Dt=mGOF58u&1TpsESL2rqAM zR$gAxx=rfjX@|Y%}1Z968L`Wnb?e0)gh1q*t$Bk-`ODHAb- zA#d;!bM*37o1}y!Om|lB@Cvs4BFp?=!BV1vc0VvMU{K{%sCoc34?%G7Nka+>_>fm{ z1*)p5VPRo1P-uz{n8e%&g6v-z>OBxHK#a5u4GGh`!hk^A+1txSIZ;57@TBjjq@?r; zY+({b^${WA;+tP!fVg?{X6~Y!7$ZOz#JHBrpvX$KvL!z+uL&;I`Nt=U(`U|D0K+Ae zqM{_~%V}M>RxHueC;X})qo9KEn=#!;((rD^v(GoR_!wrtzO>YK6iSGRi^E4~h3sA! zI+PFBmjAROAt5=(#}`^!DvU?QWT%af=;s^X={~iX=f+sgI{mY}0;k%fV00oy$ezBh zz_dULYvL`ii6?=Dp65x=;_OL5PxPU!)P>cW8&6`ltG^H^p&OxhjA=}*C_lp+A9pao$i8yg$)6DQJ4YR0~d zl5ipf1O#=X)xOYWBDTi@nOmZnTj0`DyKeJ?ym2i_O!r3dyqg$w-*k|a^gKQPJY$o4!`a;|*Mq^84`n0Nhmu?;YH1b5WA!uVZdKsa9%)PIab$ z^iUq8Zd2*K!=cE93nxI-<4vIH8VL#Z2}K2ggafawp94aUKC1GJ_u$XQIizA1$~P^w z<>iz9cZ>!93N&{-gq(no5X5O`<%@DpU!QDx z*DDyTY<>YTtf{Xb3S;QT&w*~ti&)H(6?7bwxd5Ig3jQ2=NgB+Kv|?`OVtI_3nWcX8 z{pQau{{#N)=wR$f0jLT;KR?= z1#G!v^=7Q@UkJ9D-&f)~+uj6<=UqSwC}&X@jFScAA9Q*sERTR7oXV7jvXFVT=RBSb z{v=_qbCFeBLz(l`_|%l8E)!@9AZlSDFdc)Qi3y*lD9+Nx&C$zMP*Wp4qm~#pH+LHf zW@ASO84y#bdeC+IgQ#M97jT6z3sF&1n?nZ#V)0&Wtu&B>;Q-zWngn3#6>=PX1Y-`% z#fwxhQo)XHf-ijs6JV|YJ3D*oIl?brzP#OavbvA?T3!)PK3VdJl7=SpaBs-5wwlNC zgs8k5HryID5>i`R8}{%aI^(4U9vxx_AuJhcNjANsX8Z&Q8$Z9skC_=l*o5eG7xV1d zX^_3nLKl+i`-f&5DG6D#rDq5h0smNVP0pHDu|Zay>c+z)7$I5c!AywD^+kBkZAMkPC_JkAKL_kR!^`2!!sa+)KIk!F= z3yaLIf&5}GC-x;lLCS{@A8JrFm<3gTraQKwxiIHa6q|&V%D35{NOsor%yL z(C#^I5wi`5HCbxIfFlBoPLCft`&FJ6d9m030BL zOS*|_nYP-MP(tOPU%_{xbQ)|(fcS%#JOCE0!W#qK_Bg7)K?iW!SuwZ!{tgRxF+~lH z$Jz&H{*3hs{ut}M9m2<;n^V+vW_)A5o2MiqJY4I@{&>&VuV1Z(0uDC&k)ZG24RY6j z60N&=!MyM7b$e1=6_L@3!4H3GO1odU3s~T?f#5^+w(#)q$DlRdy^9TWbBmQqJq28j z#||x!=5&HqX27?rMH3+~dN%*~{IoYZ`jqHhsBIQg&5=N$G-Rd(V03C>PVlK7o%eqE z?|@+5e-#L3dj=IiI~uiT7Wc3#Iv6DSkRVfyW7R&J4e&5l=QC3*0I&W%2Jk6|loS&{EIAz=DwNOs30RX% za^rF1!R?Fj9&L?NmDR3f>gpl)?+@^#x93WlvI9{CZ1VlC+ww4Bp5!yJ)2_825<=>r z9!@MQ5FzI{IWMCg5H>bw$=~d1LrEF2%^0#`pHH-L*Tp`IjcvGn5r#uNm=SHfuUAo-obdM!dsjmXnKkU&XyW%9!8fV_*_PDf8AGX~Rw!M8@#@kyI$S?t~6|)2}qztGvKyHq27UoDetvh;?M=CvW z=3YFX%mY;K6B;=9;f_IVK=m%Jyb@5L*iHwoia#8Ng)|uG>3baG|C_i_NU5NIs(d!N z5fHCqYwo-E@83I3emoAq*bJ7^${MCDA~`;uo{9<#Lfl_JNtWBc!o$PM+0*3Kd#i!d z0*~_SS^N&k?Zn--g)6U0sICFN#CVB&{Ct1~O?&+FAbm*5KC-RaKo2%QINdUb!jV+t-!$Q@o| z!|SV0o#wxB0E;}eH+B?I+02F^&kwkDSp{}edW~$BdWsYqC+Af_%f}rZ9Sc1c4N(P$ zN`WGd&r~nEu<8T=$D9GF*^U%GBn-H^gbFA*FxX~AWy5lEad{7r?qqlx0f^0-rltiY z&W$+j=*au8KJjw|mpLc#dRR^b7T}j}Rkt?#Y*m?yfk+80&VE#kd zO0Xk^14S&c(JA-o)2BMXCtYA>(^r3NCbUukEOAan_A6B~})a%28mNL(%6#ZPDNsd53lg0kv&O&**^TuW5+asPSxtVf3IcgMHU@H?96@4M% z%m!1}#PTwkw6yf;)2CU)#TfuR&d^3G;wWgo>b23-(FuXx%69%dF;rd@K#zhU zGr#b%M+yeM9?>!5QNyJ4*+Gi)vnHCFT{c6|2Vx#SW`T6T8L7(f5dfHH`Hm;48)tM8N zl&R;!b-h9V1d9(DBI5BA2#@1E01Hsy1pF4J@J59jkby+Noej_HMV#c3H8*EfjHJKM zDDGkQ=`pL`<~=-;hV>3QeQf96If8%%2<@ z*>AJ{Z-7M~@W`QU@Zs5H8R!f^ZmfJ$;hPA?XQ~6c=g=mJl+VWP(C99k;uivzcrg4= ztrVID9$eCUYY+@PpTxmNH!1Vj$v*?cskSpucT3--{01z2!4*Iozkc&36&^gG>PA3t zC^FfY>%xKNb&i``4!l`Fi}dt<2a&3$a&gN<*OIT(V`=y}0tBON_dY!X1E_)6&_;9f zf>Ed#8$0-{RA=^UId)xizy|yNoRai=dUjD!IvhOW-xTLQlrx9!@{4ExiZ@KULB|Iz z6A*i&>ERlUm#?pQuafOWdezFP?Hz~Z;l^%C5M4Z4v({}o`ooOyG2h;x(r*mB5ir9K z^*9cdkRYf(8p;YbqO7dk+0zpOBVtHM$i<;$&{>f0csaLjeeY9g1J^W^s*fK(){Tvs z^6+tT1_L6nvpWy|^tZqlz@-mbiaPQYY#nUR%+9i3xbVK$11!FPU66cJ>bKX6nzL7H zb}`(bijNnzFcoFz78Kwkeqd?9(14Y)1@$9$(zcs?x&GFVhpc#$WG;6;*Wuxxba@h; zr=MS&2(`ZyY{?k46JiI7AK?efUh%L?d7$e+8$CU}hKUI&U>ei|mqChv&-Yt~=%CU3 zpJd+Zm!EIm1^N$c95C<@g6Y(b|8qwFLa+EfD6oyYn+v^XSrW~K5}dbwUa#B)-qxo2 zmgCD$H_8@o96oq}_o8Mfp~7b~NA(~_H@D|`279m%j6l%v!Q?+++`a{#_PR}74WsWw zYD$h*M1AvxRjytQj*cd?u&~g8x(-$HdbOsC(q~}$fQo($oMI${aEYz1AD}e?*7$?< z1|mMBEFd}dy^$l=iSqa%JR2y+70ksJO@x=60D*&ov@-14kv&!wg=?cy|12gZHL4V7 z!dx+M6Tl=3Mj2zCBAUdge2pZ@{sibvq^1GCI8Z|b$T`=*9s@q>wi0_)0O?HLKPYnT ziG5Ls1EiG+?3YD++t9@S0poNf=lLrA) zJK02IDh~h-^yNn|5jNNfq2>y&y~WaA-2|9Y+}$tvZ2i3BZr%SUdB;|z!gDzaO+9^LIJ!qnkFVufSf@nm=Lc06`7l<15_t_?GI^(|mW;44F@}G2sOg^v<^DLKb@d-}k7PKyPyP$s zBkJCzQn<6K4t6^r_HH&p9IH%QM_1RpE(nWOz#>G~8|Xj8Y_2m^2t|e9b0vl`WW+8h zC1uP$nM8AeHtPxMEEv$${)<^p3>%os2M}->MvA|jMNhVjf2z$btgl4p?FbQHnaHIb_6}366nqs7gPkr$IhMNnEgL zT~SxZN8TEhwp+c0YK*pCP#&SRprS0)bZ{Mp!fH7s=|hE1R4_LNF>tr->_D#>-g!32 z{hP>iFGh{%AUy-Q)s(HB`FgVwXc4=C_s1$dmz&YC5fs@8-?2R=keT@GiP>I?slKwZ zvSJeupa@Shcz%|H!yK|(NDyF|?CDq;dpo<2kQ0DJQ8v>M%!22k5!Y?DBsmmA+6S#x zJz1I{5aK@|rnAtMzTL?pfm)9sQU!$EVRrf~#wJ%U54CLqHhCN$Pnf4Slz#|B3o44F zrLh@TxE%*+42^)C0V)-4`)m9qA|QgE3VO3W6l=S2XxpF93SkQnw6n6ZWNzGGg!D@g z!^Gs&RC-A%ZXYBX`0so>op5-5?=cLrrCfa6+>H#5RamB`rtomDZ{CTn29bGrMcgO9 zH2&h96HjPY2;rX(YF;01$<{^F9YUII@2iKxeOO95niKIq;}*u$1_3Nxg3~ zSm5>;Ckx!c0R{XnWFE#L#V4dsmUmTI`EI?LlMgAKYx3Pd8J2e1b`}YVVFx;Q6BraB z$Ki%C_~$$P{9T3ry~A(Qs<^n=3zMC>0&Jxj_)YBN18w1z41G|>55izi@K{7Bj0jLQgC9tar`kUW#U1y9Px4=<*5-fi& zr2H#B$h7@kr8n}~YQogwA_)Q{n#+y>fTsLH$(l-v`M)+I=Hc{$(<3etMEt^RAlW~) zw&Ebf3_{?3FkTun_9%j-3r>&5p&82}F&Jb}iH*_c!xbUNK4e(OMPJIXgQG#TCKF;rvFNsKapFZR5eS zqFF*?vZ=GlUf9rcPveo$_hfjtKKrXEO-P)6%R!$O+a~J6e5ig92V06TB27a zi<(<6D;QOYpFX_@0Y|li8TZo~i^nJt;0OPK1Wb*X_;2baO8S^_twSzh~t#iNPg?9zL7T6+*@$| zHsq^pd-Mr5=ew0)wt5Jb_=&|u9`Kr?CLU0FCxH#a2*m2k0tmb`G`s(6{TKpu##UQj zU;ix3s=Wf2=p(PFshtF$Igln0H)F*tEc9-%va(_abcM{h5^Lmba2EphLVMXmk{{wf9xfsG4-PWC9cfx*9Guq z69RJ#BHQ?4>6o6rJxm^8q5bVPYa{Ueleawf5G*k(A1T#eft?q_jDYj;Fo;Rg=N04) z>pLnIhCRppy}*RO3gjKLl#~?k`~xp&2$BwCL>mmwj50G1Po`FqtU4s{yphO=!*3r1uXHgl3rpQnQ3+TIJQl*P zNR`(9ILn4PUnW~E=X^GFZtK68g!$jfy8r*e!V~}4H+U8(xBt{P*yVl%gYXKxIdX7n z-v_e`npc81@Z-miG9MfHwl$Yc+$CIC=Cu4~2)qt+T@x@cAwZ{PwV}SlMVO^fS9e>2 zFb-;K?kq5shJAPv4<=QV;GY|- ztwq3(2LQ>iSeTX=JBWaon5w+IyrH{Wdt+(D2(2$bgm0ED4wVXvj}8=BD*$UZ2pJDq z@IxBQ%gYlWX#h`Vk5PeE#h0S_9+}xam%r%v|#A?XS;dU(_=pyG$eC9cv5BGn0M0Yd& z2e)9jj6Wn_|qKMv4!H6H5kcI}xC1l-Ldf^$PqbP-Q2;qyRt@z1fZ@2DB*y5@9X8dR}_H76hVNj4TCTXYKR1H zMI-8^214TzgD@$21OoVL0F<6i!itedvUvJW43jLN=LdjsaB$=4$R9zR=af`Cn`OK9 z3K_vix<)#96JYdiSNU_$nsH$(c=z+!6tnh3Q4#-Lw}?g9{XKz3sPJDjP=a!Q2pl%h zm*e->nAGs!FsWhH)}ZZ`Yu9w7w;=6W7+pdu>GPqn1|ls)C?3e9xA-^gD4v%4}`^?;|Iq|HF}!O)GE(e(*NG?A!G3vn2tp>$VZl z{IZTp`a|DTrKL4w3tXg+)NZ-%<>iwT82X>e$^DHV(OkZUmeyUckifPFD(3Y-02!kg zZk><@4|n5?UQin+4-cwCL%Os#{N3NlnGAM;X!5st5};eAdc08g%&w#FWryoc@ij)& zVqgA;)ZG5qAs~>Y3eK=xU#fguaVGz`}dAa#T`VWiX2kB`E|K*0ezk%ETCx`+@1Tn{piGWlR@ z1QX!zWD5e;s|GljBN9wU6DZT|7_iQ;5749Kx2sg81ZLoWvm;toGB*c8i9!%GNv)bh zjtvH=lZY8;jEnT4S?p#1P<0+8I)i{}snG&$DO5Mfq@V?2Hb7M6#|{8tsh`!JoI5=g zXBt2Ur4Y_0IS(9ZIH>SoVJ3z!x!sm)XFOzm(3rP6pV~KR0^7=^_CPTPOu>a zNov-;(ba3QsCU)(t5p%2U98<{;xn{gh(fhkBA9tMS&!hQXARSRfV0AY-kZ@quW{o>B%CW@I5JSI|0hZ8WND4atD+Y$c9SxSg@9qDuCcN^aWqW6 zKLvgcm6E|}6i%B|598kuu&yTYeByy2Tj2l;JwZcXeKyMCZ}KeCLJD~apk+W=d;H=> zSWpn+2N&h_YdQ{%5}?ZT?>Gw=agUkXTtTOQ`+##PVL!}( zu>=!I6X*puBuUurGQg+H_YC~sIe6(m2cshvU;%m|;eBCudznl@a|P783LoX3t8fnv zU|xuZ1i|EVoaqC_bmvXCEXq{?j$y;9hKBUOVIT-(nmktRvIHmoFr7YeBOuKP?6au* z0zuNd2tYmt-Uh4)WnNZ4mda!~Dw;sbLQfWeX_(l$J+a=lp!$J%;{$VmFOV!Q7scc1 z;%SazBw`I|OF067qqo?uYueD%>Yo4dbUBB~8l~uXLbu`1kxhXdwPzMhlV`{0ry~Pm zw#`1R2+&I0d;#P#Zw3KtNbcFoKbBAwnzH}n?9R?q^kT_8!zgpg@&O;5ZQwXm^{IO0 zNy>2S=bH_c%QX?lDbJvGPBcj(FOQ2_8-+)`aLzoPFZr4dsydWDo(G&rVwbK3#QDKO zS;e!?w%th0RsLph&=8HG0AYrQggkhFYSm+Y>%WIL0#>I#9ZON&IC}w>Xw}|QrM*K+ zV&WqJ>X$X2ktR}?voEDSF^Y#=B^W|byIa+IyExzy-38E=BcKk}4-E}X1RVX2r`LX) z*>W$AdmL9@Gc0# zsYr(aH8#R)>cRWfaB_~xrgqNPd80ERwB_L=y17mfH*2$3Plo6K(Mj!$=9?cceZU5_Ov+hhZK@|43Mf#HU0$->iH4 ztZG%Qxp*WDb-*b<%T?=Y`0ZiC)DY)$u!a(V!ro3W!9XqqDAl^0L-5j}NBDGhI{ETu z;}iRm%RK>8{ty}(hceA5!S14O3@MEkUNm8;uE4V?na4(y(rSA5{Nz_9M#IL52Q3QN8n)HKu zi5>HKEG+$A`$dJq6ip5?mJwAQPajp_+AF zBk=T*0?7y%h8VRGqwz$aYv9phg41rm1ifCeuS|mxA=XJ-hFV}bTIIb1S?T+0Yc8-q zCgDh}YB~S&*Wcr!2bF<|ZPagFb$=sMTEWuNGNJ|aTGTE7z1-E>H$&YaC|KFE3dRO( z$OJ*U8XK77yF5lE7l)S6;{w1D=LEwIHWIKJVTyXsNFz7l^BIrUrH^pNclj2GNJvoA zCUnhcIHAlB3O^DA`+}X76${3kV3?I5G}h8P&lu!5rsVknOl#;~Mk9~Vu~6+3^2Am{ zdb+x)U@peA084@TWg*q&1m}rCgt}s23gzlyib{u^CTOJKuhR2}Ry~m#%JjRipphB4 zFqHm$2MHm!Ma;fYQ_P8+xZ>+4yz*zx}2dF_1GI)#et?>N5vB;$6^8Zj^=XV=Ta%^vO`y*T+{7>*R5Jf7ogIy0qeGA~0 z)slJ2PmI}z!@-AA(4S8qcU11WaTeUm;Kt&)xvHQhpD$~6_x}M@oL2$> literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_5_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_5_0.png new file mode 100644 index 0000000000000000000000000000000000000000..98ce16c3a34a3fc57662312e7766ec5663b53152 GIT binary patch literal 11208 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

?V_KWo!*yct&fmYw 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_6_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_6_0.png new file mode 100644 index 0000000000000000000000000000000000000000..c03b812054929c8418fcdc310551ecdaa23d8ed9 GIT binary patch literal 7598 zcmd6McQjn>yY^OsM33I1iy(+z6J2x?HKI$DD8Ue2qD6g0lthT$JA>$Dv>{gY@2u}Vf1S0a>@~CZQ}6q_?(2F!YHKPJ-l4q%K@g#;ih?c#VF-ZhT|6A{ zspHMh0lviD6%F0>oNe7bE#BHd8W!#@j?V6mc9!>GHgDbRoSh!=iSr5a+Pdjp^I+gA^nHL<2aBez{tjNBlI*y84mkuRHP2SE&UstQk@d41cNduRA;y$N^k z4-E_(`vo-#X;fffxDx-pPlXs+26WLsIQ%SM6l$c((5 zg}Vg9w{PDTcXr;42xY``YRTp3TC@gY>=?4gZBkpp3TtX87yQq84-O7o_Lmi33(;on zXliQW-MJ&DqJkGnK=VF1nL7X3fM>tfH?g3@LwBx-_tn)xI5gAbp~om%~VRGKz}{KHw57Sy(Wy4WxvL&U;~{rKLfEp7ZZ; z@hN!%v$9yhCUJ9fFRrfItVRT6j@z4DN>v;jyybb>NDXEX>S5It)fTTMbKBDst^d8M zyqu)Spsefk?|O=(gGS)~J4AzjdKRvC$RT3HC zljo6@Wl9lsRzmO2Rk&}C*rI6!t?{6H92{M*FLTtA_NJ_2+eSypWMpKLMc&Ysnl?=A z3a40ggc8=hUA+UP`=ECXt6!65W@h#~{TVCJ>-qUp(AdD(ID(8*v${Yt^Vm9xxyEjk zW8=tM{fpo&Mn=Yg-IcX9oK`VJVPPTv+utfT(;3axFs!mA1Tn_%f8n)pbVgLr1dm~o zjcM{hW7ZutH6HwYurXbgH@!0_9lnsK#ne$Fdwn{XUs~#<*QBu138wMr5g7!U>!C#7 z=i$LNr?+&ND1M@&Lt5iB7qP$6ZFTUw_vClHmdj!*h9k13#4l1LNHecv2JS%ErD6rA zizv3*5k%PA+e5Qo?MJ^2q=;sLkOMJ>cl)+L@nBzH$M4?w6ciH$MMz_#RMj@fS}tyG z`=cw*dB>S=WzALPCf#lVA08O+;j* z>)$nvs;ztW_zeUCaN}qYqV$q5g4?%mDhxUjo6PlAUqYc~muu)mofZ!_M?+y*Sy=;xoBkLuB*2FXAG8zn7zTqyGEm}(95Ic>y+5yFwkr0Mb~SgmOCRu zTZm}{vpY{?&?7StR$zMiy+hPAnL*i0#V1cNK#I}R(|<*I?#_zOhd$A_NWwY?fU+@B zLRb3Y$NT(zE(K*}Rv{sB`7k0yuvvs?xj8?dkl0vakeOerJulBZPR`C?3Y%z;%@OvF zg+GntPP}@UsG4TKb4-YqmNv?%kiGI2jK(r3ClR7ySMlR(cR4|B{loHUC70O#lzjbdTAGZ zcIFLmBSSfsv8T6Jz~Q2oKDR&Bv1DXK_XdstVDAWiNpa)sHAWr0J$R{^Dsd})GlvcG zdiRbQ{B>OK5zRYX`G+MzvFkf zCR$2>29G&?bdzUd{$M;s=eZu%AfGA!wWyY`Q4Ka=-l~Oqg)z!hC(Jqma>a^`zs=ZC zQ{B<{@Nh-1U|j#d=H2yR$F!l%dk4QT*>gzXa47HmXWKMQL>}(vd_1l>U*wJufk36v zay$D*%Piq#EpE_HZigiKHC=Kp(k1Os&d0(WG!Y@|+k%K5j!mu9pk2?tz!cFE(>w44 z5|VeXoG-;aaESiu@zPq;ld-0BKviZe>m=@d*HFf|ak0iRq9+$j_I!c(D{*=HW3J}r zK&*h{87YkPX2#4#L2Z*)jrZ3{5Y3KUu^0U;d6waE8l(%UxIas2O7xaj7Wv({$>HA< z3R&DfhT?={g=LuhnAyOMmpO-?QQi@_QejPDsU)T@+gK$ItEQqc|D^jZHN#tsl&Ix2 zXV^Q=2Q#z2i)GzhE6OoKEZ(`g_^EpNiF1|pz2L`hQdhg8CEhorSVhKi8H7q>U%2uP zO?f$l=;ONXN`1z~g`YO2{uzBDva|dB*V6^_ZE{N+xQDS9!nqtq!%-l^PiQ)u`gJb1 zt^vzlcJb+w)`KFRQL>d)w&_HqY=N_zYlTXc&oSzWudkGpv~&j7orw~YS8=d{Bl5|H zD_%M}o)JDDOKYUMZ_r3MDXYux9@1w926Pi3{j5f^Rq+T25DkBt@jX2~3Ft)n+e1eD z;G@WLYD;VM4bVhH+$lC~pp56xsDz1ITQq)SYsedZ4MEM#JE8%x#bMF{l@5Si>wHfI zA@kooaiK@Puc|N2!{bbS{xqS>-PSdWjjC|)srVEW6oTPuEcjO7uM{y?762>dwga@; z+1ciZaMB6Bk33OU|4rpuq8DsvWJEJEGBQ+VCRFbWPKVI=K?!bS0WNcBvn|s$W>XgOWh3{Ys5&ZgY6o%^R z1l7j8?>~H40<}@+(~mRCS^BY?WxL8$qMXHkk9x~xcG-k|9Gf>KwrUT zW^9at=VUsUj~`{90RlzAO7tU9C`YJ^Iak+6X41;aija7%DzrP`l%?LwD?>r=eQRqg zM__Z9fqG(j=OS^SG7hpKbiw zkowtcN7r-Nc3eyCr0-oh*XJ$k7JWxW5Cj;XRXHZv<0Y8K*RLkdx&=i=4zP1jo#^Q6 z<7jDV1qTOLJMhv*<0vXB?s&)e3~#%KmVs-H#5W)LEX#-APQwMsFAeQ;?2A=gad>sMc z+^*%J0;UR78E3{Me&cDkmEl*~Fsif|#80gQp0{a#*MGrJ=2fAgt7D3Aw*|UHgJLhL zKkT(qwsXcX$@1@siJ?w&^-Dh!9)w3k$bqbvlb088-_SnXK~iNYMPr&vF)CR*lixC| zJ+TnWCsz;f_`U>-@RX4V>BtK}jEor`5*{{cJ*XLQlIH@)c_4)`8qwzOb=hGh=ChfHynpB&L{qjCmi6IIz@_Pkv~jr~ zP$Rb?Qc}{Mo}Sm0&Gq%Pw{G3iE_g=GZyrd&&1xTTDPM27kHU>}TjriOT{whAG~!e2 zyfvC021sE1cC8<9_RZn~xx<01b)3e8diwev850o^DLFbic2hhZ!+G^^F3@E5%xCxS z@l3pz&rUB6sV3=x2 zIuD^H?ak6VMmP-?v9X+b{7j=JohJVOwGF04G_BxFJ3^dan3ZZeH%q(e78>nRC3=<> zE={i!J*C|iUZlR=Wt-;f9L19RJBo}(bgH$MhZP&fdDJzCXP&hR-6((0+Qb!wu`x_` z&!(E8EVaLqDdEgYB8nd)0>uK_%8Lho25l8w2QQEPkSUDFoc)_aS4lc89;kmldPiBA z%OZo)E+r}6TJJN$YlVWHb|bMQkgK``ZKb;%o+6sDP{mX)yd5?1-~+Clg;o?Q?(PKf z#xz#lS(Zhrm^=B5ymHXXD{Wujz=nAZ)fyGZ}ogm?F;R*Dzq(-4lb!|%-n;X2&nsV7$w;Ub3Z$Hn7AN3iPzUtDqce@CqU$|af(T<#ZCf-gB_a>v z1)nrdpj@kL2Lz2pZTqRS^YXI(kI3K{*BGND5TL8J?!Ei$*|WvTmMgew_x*_XY9Z`X zmjlDLwUZO$D`nqzU%MLR=Mx>Q*v!7dz-OzbhHwiIELmS*_7KG!iY#bcReGglNjBCMK0(b~Z`ZTr#x?Sv~GD94!_Eos9 zC@_zD2ywJ$*Q|hD^w`$7wzdZD3Qk$emBhUFHt+n)C;Dv*nlliyLJ_*jJqJ5zi_zt6 z{k3dr(km);U!mLIeJdKKcXpllyev_J>0D2X1_O{lck(;YFEnaQbd$uZJon(8@UO>m zD&X+X*UctC?!MlWy57i|XdOQcB=siTP|%9~WZrzdO_hD{NBmv{EGI|3`i`jZ7t`pm8{=UV=_*M=5u8PoR+U_oreOqL_;=_y6{ z9I9^B=_Dt|2u1YE^@7}+E|Hh+=7^z8X_qmpK1Q+YZh8;pY%JU#LE^JW%+LF7<;cQgRE zs@2HqbYQr#a&qQ9KY!T(BaD^35-=|Sf`P<9&{KC>l4I<3gh4%Is(5_Rdi#z|0(u5?^Zp?lO_1hZ8%aBo8 zgVXo&9Y%CCAqRt~)iGwUl0vQC^RYB3>Dj&ZLseUbJ^=v;Nb^qMhb(Svgr`b+S^_s$ z33+*OQSP!NSA{GqES0zM7`XIw44J7v6RFh+7_D~Mc&*%gn$(Md15NwD+RAF*#Qu$2 z6+l3abM+LhB}klIB7U{KLzhSAhH6Lc)^AIydx}?{Mg{~Xg>6dPR5sUKFj<6S^z=0d zo2UIVbXFjd%U_#90MT6kY!g-1WaermzCP-=vYi`cPs#f7ofTca*KATV!k z9K(9|`}Xz{Yq~kSp6kd+aksVVv-^zu`}x|{_4ExGH-OP{t8O9y-2ZXBqoX^k?M5YjhuxVL2~CbJY?+3rUgc>b@mcM8|5N;6 zo&Ud1PmD~JlyJ__e`1G*wAH@~_3k~3o2d6b;_ix~`2c<*pyr3p(F*|wULGF8jDCkY z?tkV}(O*?#n3eROo0>)&RoPl>Pn3uSTuEVKVwQXDTgK0LovtR4GBL#hykE(Rm1!T< zl8x@_>hfV+0XuXHpVAz?ySC7)dSD)|(*WG4HbA$eWMm(LuyB_nA2z>+wcN!2-eTLv zLW?Z4c)I?*J69t`U1BotyT85Hxz~#q^fz6BZM!&GiNzx#>H<$fkV%c>6Cf}Xg31>6gp0AVZhNxK3IxDZr49b4PoL5!w{>)MhEdJ37kgMhb6FYQRG@&_fFuPE z|MU6t7|PY(-~Z&G@1g6?j4;sHawYn7@cj;A*?T}K0IL)6`MzE`u(%sfmLq%m`-4+b zPGkL;ksTzgk$t_rPrSV9m;;}2Q~3J%X*hKQEB(ihA8!iT@87=-c(}dXq655efaeJ> zkgk*l&QT%oG<`3RCPP4_iTW&!AJ7w@DNzVZg`C&@bw|x;zgdkpm}CVBm0DbV+eBIk=Mqh#NUPX4}Cu zUZCn;jhyCcedn9^S|MZ(CJ7^AxQl^-k(rV41dka3)J7+3tP~5NUquy_@RPL^=ct$_ z_svfmGw>qSbyj3MNfsg z!18X-cC!D3Od?B7@%bU;ll#AzKBvqc) zn26RGqnp$XC0|R~%8t~^?EOK-GJXGyb&@kxOKG6wmQP)Sky-p`Z~1UJy9|i}p}aiN zGd?(yynJ~#0W*`bWh7zZR~|&;=q{R<^Jw^2SGXV_^!+TU2GFr6m;ry5C%#ln|gjNCa zTJP=m@QN-TAv*fhEi@Am&K=xA4qT`?Tz*cU85I?kNEC`55>cn$$%S);osAA*ZgMP7 zJA80ci;a!9KlOT&TFm}D3^s%n>3y(Ut{fkgs6|*>lB*(F)T~XwfO`I(;9v5PQV#R} zoc52JuTYM6&(YV@3f?5lqqZRO|$cwPxQDD zM$LY9IVnksFGv*Fl2znVa!L94_%K4ocfAm8$lwAqpVEa-Oj;yby5-z(O2g`U9+wk7 zhO;B|%*@~k?Q>BcGrZgw@6xeh0zO%l0;1)B)41H>@$WIv4h#iFp5 zqF;$V5WJuf4h45tun19EXhEsXV0F!P*Lf*I$p;$!P}vPvJU+o+Hi*im+no9 zbXf1s5i=)k?(M~x1>KWExP6Yy&;8UB_-S!?c1j47G(x-heOMS;W>!{x z%ggPaFzgRQR@>91`qX;LUnRm*qe@CjdNic&-Cm{4V;0|LZDV`H)8Mi7G=?)wXk_{GJ=Ma9K-?wu_yqQ;$X zX=f|V23C6`eipxC#i11?=?%vXO-@es>x@9s)7M9b2>YF}$;HM-4<$sAl94eJLjx zOQR5RfBM^9WPg93fQ01z-CaPy$q;MP+j~)PM|8;cVr!!Xwo^e(4R4uIqdKi5#Qe>h zu+&rv94dZ{j*gDF_#jeQlsXSSi9eAXjfv6OuC?PQi!?xtp(ZwrL1JG^Pk_B&?GZxg>h%IFxdp50H<89x-v zK}Z|2-GZ2ma;vHcEc;{M8FLMUpkW_9+#dFJcOyZLRwL+PKl2p0g@TR<8pp>qQS?h& z*VbTV2Gz*d*VntA%!;vHs?c^2iwo8X_4V}%R#s1$n3)qZGGgMWh1TZl9S9T%S=BQ& z4_T8T`Qe`fz3?m_Rzf{pE_?BJd1s){@AT*ze!aXKdTH&2_In#||x?AX}Z z?N8G^t3CJhezkaFLsm97!#9Rgn1zK6wl26#+ajl?bmBZ4U6%W=Pq&P8St)0l_nDqP z%^Eneb!oeS;SX9NH&g`Rg+SEI{Ak#d>s-Qxh6om_Ezxz@Nm(?qas2&n6)&r+tC7A? z!ZtQGD8zlZ-90?2EeG%%=j$**^ixRq@$2~cVHI>_ig~L`JXl&Cj zB7vkQm=;5YF1s`I=!@U3J6Gmn4TV4h_tJ#Ypuoo(>S!bUY;s_vp`ap zj%${K<<11lfq08GMAXapdNfqjFAWWPTcUI~#rneH&*?{BW$^l9#iyjywU`uZbtAi) zl*|gMa@f0d>S3y4^X+T2qXkN7k4iB>c&7xK?_23|x1BC+9dF7T$;@Zl#enF*$Ile; zP%J!6w~Ew#cpyvO-Q87eJp9#692OP^o+vmcC&w>PPmhd6&Gt%fZDqyW>dl)S;{;1gcBk=RTeS7kEu_Xh1@|`xe zw$>l+Z$+n%h2NOd$8GfF$^Kq!U)=S2rc{M`cE>Oem5h8>5Jp*3L2kLTzjSqTo6(eL zRMB{WeR7Iay+dzR|5gI2RcW~IS)XB`8GqkXxsl#pl)k>c!NEak9i3184Iv@OoW@NA z5CSTy5<&?0#nsEpc|5zcl;iEg^_JdrKCY_jFiT_d=g(`P9PN6^$;!e@c9fAW#;YuP zU9XNTAkv10hDnT@8yf{F*{QGF8>yQ;UFB?4lkQRlRnf3X#C;pd{4KQ!o+$ZQ9JAU~ zZ4Fiq&WYgV1QCSF@Llfxp~*Hi9lb#823443nvB0bHxF{^RHC!_m=ixYXJBPxV>y~G zKp_feLq=Y{&9ntb{C^{b5k z<-sCfdWzbwHs4qGhXc?sBb5w@e-Stj59qgAHFQTozJuy8!S}R|%dw!luL`1~Z)3dKXj=I`qSrWW5sdO&^ zHV%#>e4m4ZW7sx(^uZ^R|2!t<+cuH;`B;7e501SQ_O}RzmISe-TTT>xXUTN+TV^E)t3F#5YsnVGRCC+?q8Qr3SDC8bLE3$k-?Bqk+IZr4^TCeXzJ zMWH2ej|@@I7LVGSt+X6T<@s~}jQ{)044JdDvnw3#=#FP>$z{^=^;IxZa8eR65DcJy z7b-%Z4GEv0dGth!j4|Ec(FW8Ntiq$q_MRDBT;kj@{vvi!!{U_=yRrCa2^(z=xaO7D zl9!g24&6bnwHfQbIp5>)+Bf*y00aaCA`=pnKu7A2r*-%eEijrXLd<9LW9p_Uo>r`9 zXb2M|so^rVh}GbSCymUB$F1(QB!YxS>5Dd=6KG}XE#vB>^|(oYq69Y9`p_?6dXN zQWxKtc?^X`D{urk{q{1VCyo7;B z|1i8^P-TvUg@yGYF%hZRI9|YE#(cRWP&n|0ALvp8tz6ZKlhOSZdtHxGM%!dzfy59WueGk94OCRHAm&Fa-7gQ4GBU7%5XkmF5FsHUF$Ys0 z85ifYz!WtfCCdoAnOLuC;O*TbMoCO(92hV&<%PfYv#5b$U7ydIAwf)9y`12!vbmrY zQ9(utl7`N5_EuL{!HW2~G!~fp_)6~Y(`qq5gBu&YL*H1QysC8dF*GbrDOAf2S>JdT z&H+o6d|}o_AIF zdqW^}bacWVo3ZL!0{;?}mX)Cb=d3T(61epvi;a`>eP}4k-QC@M9T^A(;2Z=clst4) z3T_U;@sr_xdCEB@%jT*g0$*LMx>B2Fazd%^2Ibe^g@Zn>Fr7-!ZZwOLRQv5@=l z`OI6Hw~`Dqg3awSm8|BMw#`jn4WKzvNw_>fjgXL&Gcz-zXlZFtEr8&wa$N<|$kx_2 z1Aoci$EVKjR)dL;@73dCv&R+~7qNdiPv^e368_^e%Po)7M=Ub7aZ7(tUwc+wKsg_N z<6O{OlTwNete)b-xNSGzwrBND4wwF$omx;(&|ec%i!EA8x4)czNSJgFNA&kI0R`%oQ;io)g8 zu$l8CQH_m1bp-=Taaqaaf1cbrBQfw6cZyHxWfgS|Ig8dRm^etBkxpMm_w{L z;!C!(b-0rM9Jlb5l?l`?Y54nv^#tS0r{NT+9Ek!dDr(ovOhfkt2y`S!O-&8|=fJ=~ zLOQyow_!x}J;@mbRZ(*j`;w(eT;`q=VO}LgPU6XoUdL;p{(b2!pE9{EWb=n73pEBn zSy`wPWSYQ}D%C=1}$GPmc4r6_^(2k4%Jhnc>{MthP~8!Ebg9#-vR2IjvUd{wJCkN6w90#!o9+yjlolB3O`SYbpLo7So83q#`t+RUgN z99=(=WHmJ~eyBTn(SZk*=vE7NFNmxWMKgbcUR#~7dA#HGX<7$)Mv$9Y?ECn$k4OO8 z{ZBReR6>JRujhGrc`Ivc$Tl`MI5ffp==gL1HIB}A21)r{9^eAqd3AFG0~rV)QnohG zARj({3`yg&SsP4b7WUjFd4fX`{4-yP`T6tF@dAO}ku*LEF)vQVc$%n@5j9Su2Amjj zXus6MF}_@iq6VYnztb2r!miSm*S+{si0)AI<3EkdOroOm(z*gpV35ejNNHJFWXRu~ zOM#m8?@pH<&pT97Hi`Ppb0cCus1(S)eoeW*U+3Rk#1`FjY=rcQJ-Od6OuP8uc6Sui zrv#6>#xNzNS?jT+&!59z*IL_^QS-o1iHL~-62@F?Z03<#t!t^N ziP!tJV^#Lk?ECZes)gJXG}GuN;$pk-11ZJJu*L}I0U}DkzapQqu)tP(!sc4Np)gBJ zPy1dqmR{9-^xhuhR`1(uAJ3jI5A8;Em4$_@zulYrTNWB!N*f95S;JEkeGc0%s{*dw z_m?}(wt%_FFXdCjjj}&}AS2uKu{$$Q9WuOdi;R!&zg!NgtUg%j4&9!w=YT#dUgSZ< zcHLc{Rs(V5xX^$r;dd5n%oPDVtesu)52uSg+DJ$z*YkPrvkwoh9(LEmF99HZnJMat zrTUq(JDEej>di1&nOP^@VcThZ#Rkz%ETc8*!$o6fE^xQdwj*S535n^TwY4?4^D6?> zyTidPa|fsC{kIY=o-$SjU-X=m{LM5on$z|3ir~l(8?*hX+S9^+W z+?*OUe>;5z*A=G`^I>=jW03Wapl%W8d1m>4pGug_P zhS)z=yBN{nw7~5+#|__~Bh=H=J32n@jwED0stmfv{=RI}LM`j7K&ozKjRb+AUrg^3 zjrY%E5i8SNaj!IJ3tkD=|jOR18kg_a^LPgeH-t(~iPARieW zbzA8|I@_IAwQOx|6(fV1mU-N6kWRCe76qKdKiAYXncNk$KX4$&`}1cc;c@yeWc)KI z)8x%_;3hdC6;2Th2r-Hex6_xm!8@U$?QuT_c1y`wo+&h*!bK0f9$Z}OW;+Vi!e@c{ z0VkK0p`&bSX+7`MRibY3NRxE$g&Op2XA`PLrKP=~a=Y!%@x=WB zyi*ZWTXv3xE$sq<+S8YPznVRa?nn{R@Q*C9 z-r-?vG&Hoq;o(rWXf`gc@Y-6BjMm&wET_?!X&(YJKnA)KB6xVLv9~ zB%o8f5;RoG!GkZg`&R?X|LN1Gt{*?}fJp#ZVAy)6$++H6z^5&6>0t53?s)2=C(>eu(SUUARdxdA;brStQQ7%mcz$^HvZQ101$puWL+ZqBB(gg-1AR`Ok z-L*G({n}#i1LJ;J8bmTW;_Lv-6@`#9jn|*~zk3r!I_zN9_*)KLI`6~5MI|XfgKBAN zLc(OHQy7f{kdusuwqKU`Z+qn zgZ8m0>BA{@O#J-7PR4dF9z&Yi6McRC@&z|nS7~c&>r#8*f4jkCahrER92Z+ik&uwe z?Gs}0?k1bo&Q|0XBgvi0cK|zb8?|g4ICg^URz7JHon741= zt|dr46uIq#9XmfVNrkrI=L@P_+LbV7C?~W zyGaSssv4%O9HqDQad=}5_^Lj@GGb(8WMC>P(cocxF7{tn1Ja*o%ta2yot&7Emy(jI zuBy@`QP9G{#3TgoBQHaM067-(>YLinf8QlfV2|HoNB^(T5u8hkYJiCV)+Sh_ZsZe1)ue$bSIfLxT+f literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_8_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_8_0.png new file mode 100644 index 0000000000000000000000000000000000000000..7e240ab623652b0196a8ebcd3636a81cce71ebd4 GIT binary patch literal 12759 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_9_0.png b/public/images/api/qiskit-ibm-runtime/0.31/qiskit_ibm_runtime.transpiler.passes.scheduling_9_0.png new file mode 100644 index 0000000000000000000000000000000000000000..4c719a051af09e86961962dda85e71b1351f1d6c GIT binary patch literal 9282 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 diff --git a/public/images/api/qiskit-ibm-runtime/fake_provider-1_02.png b/public/images/api/qiskit-ibm-runtime/fake_provider-1_02.png index 8257ae55c6569b0d8f4451a18eccac18818eaf87..d8038dd69d74381f9ef28a6aff8f5b63c723bee1 100644 GIT binary patch literal 12381 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 eo8#~EoDv%^-l}RyLUuH;Z^*;bh07T3H literal 11442 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 diff --git a/scripts/config/api-html-artifacts.json b/scripts/config/api-html-artifacts.json index 1d1c508b001..e50b8d08850 100644 --- a/scripts/config/api-html-artifacts.json +++ b/scripts/config/api-html-artifacts.json @@ -29,7 +29,8 @@ "0.19": "https://ibm.box.com/shared/static/wjoea4x5tnxd0l4lgo2v3kxnx6btxvvl.zip" }, "qiskit-ibm-runtime": { - "dev": "https://api.github.com/repos/Qiskit/qiskit-ibm-runtime/actions/artifacts/2082018988/zip", + "dev": "https://api.github.com/repos/Qiskit/qiskit-ibm-runtime/actions/artifacts/2128611480/zip", + "0.32": "https://ibm.box.com/shared/static/enr0tnwaxzpvrypzjav4f1vjip3yfqcy.zip", "0.31": "https://ibm.box.com/shared/static/z19dt14je6cz69oi4knraitjglzo29w7.zip", "0.30": "https://ibm.box.com/shared/static/f950vkx3uq13o8g017bazpm4o9bcei2i.zip", "0.29": "https://ibm.box.com/shared/static/9n6xf8gkh24xpft2e7zrwgme7jzkh6nu.zip", diff --git a/scripts/config/historical-pages-to-latest.json b/scripts/config/historical-pages-to-latest.json index 519c8265483..212b42e3bf0 100644 --- a/scripts/config/historical-pages-to-latest.json +++ b/scripts/config/historical-pages-to-latest.json @@ -19220,6 +19220,7 @@ "qiskit_ibm_runtime.fake_provider.FakeWashington": "/", "qiskit_ibm_runtime.fake_provider.FakeYorktown": "/" }, + "0.31": {}, "dev": {} }, "qiskit-ibm-transpiler": { diff --git a/scripts/js/commands/checkInternalLinks.ts b/scripts/js/commands/checkInternalLinks.ts index 8db6bb331ec..e17a93aeba7 100644 --- a/scripts/js/commands/checkInternalLinks.ts +++ b/scripts/js/commands/checkInternalLinks.ts @@ -189,6 +189,7 @@ async function determineCurrentDocsFileBatch( "docs/api/qiskit-ibm-runtime/0.27/qiskit_ibm_runtime.options.ResilienceOptions.mdx", "docs/api/qiskit-ibm-runtime/0.29/qiskit_ibm_runtime.QiskitRuntimeService.mdx", "docs/api/qiskit-ibm-runtime/0.29/qiskit_ibm_runtime.Session.mdx", + "docs/api/qiskit-ibm-runtime/0.30/qiskit_ibm_runtime.RuntimeJob.mdx", ]; if (args.currentApis) {