Hello World: 첫 번째 양자 Circuit
Bell 상태(얽힌 두 Qubit)를 만들고 세 가지 방법으로 실행해 봅니다:
- 이상적 시뮬레이션 — 완벽한 결과, 계정 불필요
- 노이즈 시뮬레이션 — 실제 장치를 시뮬레이션, 계정 불필요
- 실제 양자 하드웨어 — IBM Quantum 계정 필요
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")
옵션 1: 이상적 시뮬레이션 (계정 불필요)
StatevectorSampler를 사용합니다 — 노이즈 없이 완벽한 결과를 제공하는 로컬 시뮬레이터입니다.
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)
옵션 2: 노이즈 시뮬레이션 (계정 불필요)
FakeManilaV2를 사용합니다 — 노이즈 특성을 포함하여 실제 IBM 양자 장치를 모방하는 로컬 시뮬레이터입니다. Circuit은 먼저 Transpiler를 통해 장치의 게이트 집합과 Qubit 연결성에 맞게 변환(적응)되어야 합니다.
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)
옵션 3: 실제 양자 하드웨어
IBM Quantum 계정이 필요합니다. 자세한 내용은 IBM Quantum 계정 설정하기를 참고하세요.
이 Binder 세션에서 아직 자격 증명을 저장하지 않으셨다면, 먼저 다음을 실행하세요:
from qiskit_ibm_runtime import QiskitRuntimeService
QiskitRuntimeService.save_account(
token="<your-api-key>",
instance="<your-crn>",
overwrite=True
)
참고: 실제 하드웨어에서의 작업은 대기열 시간에 따라 시간이 걸릴 수 있습니다. 셀이 아직 실행 중이라면 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)