Hello World: Dein erster Quantenschaltkreis
Baue einen Bell-Zustand (zwei verschränkte Qubits) und führe ihn auf drei Arten aus:
- Ideale Simulation — perfekte Ergebnisse, kein Konto erforderlich
- Simulation mit Rauschen — simuliert ein echtes Gerät, kein Konto erforderlich
- Echte Quantenhardware — erfordert ein kostenloses IBM Quantum-Konto (Einrichtungsschritte unten)
Schaltkreis erstellen
# Added by doQumentation — required packages for this notebook
!pip install -q qiskit qiskit-ibm-runtime
from qiskit import QuantumCircuit
qc = QuantumCircuit(2)
qc.h(0)
qc.cx(0, 1)
qc.measure_all()
qc.draw(output="mpl")
Option 1: Ideale Simulation (kein Konto erforderlich)
Verwendet StatevectorSampler — ein lokaler Simulator mit perfekten, rauschfreien Ergebnissen.
from qiskit.primitives import StatevectorSampler
result = StatevectorSampler().run([qc], shots=1024).result()
counts = result[0].data.meas.get_counts()
counts
from qiskit.visualization import plot_histogram
plot_histogram(counts)
Option 2: Simulation mit Rauschen (kein Konto erforderlich)
Verwendet FakeManilaV2 — ein lokaler Simulator, der ein echtes IBM-Quantengerät einschließlich seiner Rauscheigenschaften nachahmt. Der Schaltkreis muss zunächst transpiliert (angepasst) werden, um dem Gate-Satz und der Qubit-Konnektivität des Geräts zu entsprechen.
from qiskit_ibm_runtime import SamplerV2
from qiskit_ibm_runtime.fake_provider import FakeManilaV2
from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager
backend = FakeManilaV2()
pm = generate_preset_pass_manager(backend=backend, optimization_level=1)
isa_qc = pm.run(qc)
result = SamplerV2(mode=backend).run([isa_qc], shots=1024).result()
counts = result[0].data.meas.get_counts()
counts
plot_histogram(counts)
Option 3: Echte Quantenhardware
Erfordert ein kostenloses IBM Quantum-Konto. So richtest du eines ein:
- Registriere dich unter quantum.cloud.ibm.com/registration — keine Kreditkarte für die ersten 30 Tage erforderlich
- Melde dich unter quantum.cloud.ibm.com an und wähle die Region us-east (erforderlich für den kostenlosen Open Plan)
- Erstelle eine Instanz (kostenloser Open Plan) unter Instances, falls du noch keine hast
- Erstelle einen API-Schlüssel unter quantum.cloud.ibm.com (oder unter cloud.ibm.com/iam/apikeys)
- Kopiere deinen CRN (Cloud Resource Name) von deiner Instances-Seite
Falls du deine Zugangsdaten in dieser Binder-Sitzung noch nicht gespeichert hast, führe die folgende Zelle aus. Ersetze <your-api-key> durch den API-Schlüssel aus Schritt 4 und <your-crn> durch den CRN aus Schritt 5.
from qiskit_ibm_runtime import QiskitRuntimeService
QiskitRuntimeService.save_account(
channel="ibm_quantum_platform",
token="<your-api-key>",
instance="<your-crn>",
set_as_default=True,
overwrite=True,
)
Hinweis: Jobs auf echter Hardware können je nach Wartezeiten in der Warteschlange einige Zeit benötigen. Falls die Zelle noch läuft, kannst du deinen Job-Status überprüfen und die Ergebnisse unter quantum.cloud.ibm.com/workloads einsehen.
from qiskit_ibm_runtime import QiskitRuntimeService, SamplerV2
from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager
service = QiskitRuntimeService()
backend = service.least_busy(operational=True, simulator=False)
print(f"Running on {backend.name}")
pm = generate_preset_pass_manager(backend=backend, optimization_level=1)
isa_qc = pm.run(qc)
result = SamplerV2(mode=backend).run([isa_qc], shots=1024).result()
counts = result[0].data.meas.get_counts()
counts
plot_histogram(counts)
Was kommt als Nächstes?
- Tutorials — Schritt-für-Schritt-Anleitungen zu Algorithmen, Fehlerminderung, Transpilation und mehr
- Guides — Referenzmaterial zum Ausführen von Schaltkreisen, Primitives und der Qiskit Runtime
- Courses — Strukturierte Lernpfade von Quantengrundlagen bis zu Utility-Scale-Computing
- Modules — Vertiefende konzeptionelle Module zu Informatik und Quantenmechanik