Hello World: Circuit Quantum Pertamamu
Buat sebuah Bell state (dua qubit yang saling terjerat) dan jalankan dengan tiga cara:
- Simulasi ideal β hasil sempurna, tidak perlu akun
- Simulasi dengan noise β mensimulasikan perangkat nyata, tidak perlu akun
- Hardware quantum sungguhan β memerlukan akun IBM Quantum
Bangun Circuitβ
# 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")
Opsi 1: Simulasi ideal (tidak perlu akun)β
Menggunakan StatevectorSampler β simulator lokal dengan hasil sempurna tanpa noise.
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)
Opsi 2: Simulasi dengan noise (tidak perlu akun)β
Menggunakan FakeManilaV2 β simulator lokal yang meniru perangkat quantum IBM sungguhan, termasuk karakteristik noise-nya. Circuit harus ditranspilasi terlebih dahulu (disesuaikan) dengan gate set dan konektivitas qubit perangkat tersebut.
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)
Opsi 3: Hardware quantum sungguhanβ
Memerlukan akun IBM Quantum. Lihat Menyiapkan akun IBM Quantum untuk detailnya.
Jika kamu belum menyimpan kredensial di sesi Binder ini, jalankan perintah berikut terlebih dahulu:
from qiskit_ibm_runtime import QiskitRuntimeService
QiskitRuntimeService.save_account(
token="<your-api-key>",
instance="<your-crn>",
overwrite=True
)
Catatan: Job pada hardware sungguhan mungkin membutuhkan waktu tergantung antrean. Jika sel masih berjalan, kamu bisa memeriksa status job dan melihat hasilnya di quantum.cloud.ibm.com/workloads.
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)
Langkah selanjutnya?β
- Tutorials β panduan langkah demi langkah tentang algoritma, mitigasi error, transpilasi, dan lainnya
- Courses β jalur belajar terstruktur dari dasar quantum hingga komputasi skala utilitas
- Mode pengujian lokal β jalankan sebagian besar notebook tanpa akun IBM Quantum