Побудувати моделі шуму
Версії пакетів
Код на цій сторінці розроблено з використанням наведених нижче залежностей. Рекомендуємо використовувати ці версії або новіші.
qiskit[all]~=2.4.0
qiskit-ibm-runtime~=0.46.1
qiskit-aer~=0.17
- To simulate noisy circuits, see Exact and noisy simulation with Qiskit Aer primitives.
На цій сторінці показано, як використовувати модуль
noiseбібліотеки Qiskit Aer для побудови моделей шуму при симуляції квантових схем в умовах наявності помилок. Це корисно для емуляції «галасливих» квантових процесорів та для вивчення впливу шуму на виконання квантових алгоритмів.
# Added by doQumentation — required packages for this notebook
!pip install -q numpy qiskit qiskit-aer qiskit-ibm-runtime
import numpy as np
from qiskit import QuantumCircuit
from qiskit.quantum_info import Kraus, SuperOp
from qiskit.visualization import plot_histogram
from qiskit.transpiler import generate_preset_pass_manager
from qiskit_aer import AerSimulator
# Import from Qiskit Aer noise module
from qiskit_aer.noise import (
NoiseModel,
QuantumError,
ReadoutError,
depolarizing_error,
pauli_error,
thermal_relaxation_error,
)
Модуль noise у Qiskit Aer
Модуль noise бібліотеки Qiskit Aer містить Python-класи для побудови налаштованих моделей шуму для симуляції. Є три ключові класи:
-
Клас
NoiseModel— зберігає модель шуму, що використовується під час «галасливої» симуляції. -
Клас
QuantumError— описує CPTP-помилки гейтів. Їх можна застосовувати:- Після інструкцій gate (гейт) або reset (скидання)
- Перед інструкціями measure (вимірювання).
-
Клас
ReadoutError— описує класичні помилки зчитування.
Ініціалізувати модель шуму з бекенду
Модель шуму можна ініціалізувати з параметрами, отриманими з найновіших даних калібрування фізичного бекенду.
У цих прикладах використовується фіктивний бекенд FakeSherbrooke з qiskit_ibm_runtime, але ти можеш спробувати його з будь-яким сумісним з Qiskit реальним або фіктивним бекендом.
from qiskit_ibm_runtime.fake_provider import FakeSherbrooke
backend = FakeSherbrooke()
noise_model = NoiseModel.from_backend(backend)
Це дасть модель шуму, що приблизно відтворює помилки, з якими можна зіткнутися під час використання цього бекенду. Якщо тобі потрібен детальніший контроль над параметрами моделі шуму, доведеться створити власну модель шуму — як описано в решті цієї сторінки.
Квантові помилки
Замість того щоб напряму працювати з об'єктом QuantumError, зручніше користуватися численними допоміжними функціями, які автоматично генерують конкретний тип параметризованої квантової помилки. Вон и містяться в модулі noise і охоплюють багато поширених типів помилок, що використовуються у дослідженнях квантових обчислень. Назви функцій і типи помилок, які вони повертають:
| Стандартна функція помилки | Деталі |
|---|---|
kraus_error | загальний n-кубітний CPTP-канал помилки, заданий у вигляді списку матриць Крауса . |
mixed_unitary_error | n-кубітна змішана унітарна помилка, задана у вигляді списку унітарних матриць та ймовірностей . |
coherent_unitary_error | n-кубітна когерентна унітарна помилка, задана у вигляді єдиної унітарної матриці . |
pauli_error | n-кубітний канал помилки Паулі (змішана унітарна) у вигляді списку операторів Паулі та ймовірностей |
depolarizing_error | n-кубітний деполяризуючий канал помилки, параметризований імовірністю деполяризації . |
reset_error | одно-кубітна помилка скидання, параметризована ймовірностями скидання до стану , . |
thermal_relaxation_error | одно-кубітний канал теплової релаксації, параметризований константами часу релаксації , , часом гейту та тепловою заселеністю збудженого стану . |
phase_amplitude_damping_error | одно-кубітний узагальнений комбінований канал загасання фази та амплітуди, заданий параметром загасання амплітуди , параметром загасання фази та тепловою заселеністю збудженого стану . |
amplitude_damping_error | одно-кубітний узагальнений канал загасання амплітуди, заданий параметром загасання амплітуди та тепловою заселеністю збудженого стану . |
phase_damping_error | одно-кубітний канал загасання фази, заданий параметром загасання фази . |
Комбінувати квантові помилки
Екземпляри QuantumError можна комбінувати за допомогою композиції, тензорного добутку та розгорнутого тензорного добутку (тензорний добуток у зворотному порядку), щоб отримувати нові QuantumError:
- Композиція: —
error = error1.compose(error2) - Тензорний добуток: —
error = error1.tensor(error2) - Розгорнутий добуток: —
error = error1.expand(error2)
Приклад
Побудова 5% одно-кубітної помилки перевертання біту:
# Construct a 1-qubit bit-flip and phase-flip errors
p_error = 0.05
bit_flip = pauli_error([("X", p_error), ("I", 1 - p_error)])
phase_flip = pauli_error([("Z", p_error), ("I", 1 - p_error)])
print(bit_flip)
print(phase_flip)
QuantumError on 1 qubits. Noise circuits:
P(0) = 0.05, Circuit =
┌───┐
q: ┤ X ├
└───┘
P(1) = 0.95, Circuit =
┌───┐
q: ┤ I ├
└───┘
QuantumError on 1 qubits. Noise circuits:
P(0) = 0.05, Circuit =
┌───┐
q: ┤ Z ├
└───┘
P(1) = 0.95, Circuit =
┌───┐
q: ┤ I ├
└───┘
# Compose two bit-flip and phase-flip errors
bitphase_flip = bit_flip.compose(phase_flip)
print(bitphase_flip)
QuantumError on 1 qubits. Noise circuits:
P(0) = 0.0025000000000000005, Circuit =
┌───┐┌───┐
q: ┤ X ├┤ Z ├
└───┘└───┘
P(1) = 0.0475, Circuit =
┌───┐┌───┐
q: ┤ X ├┤ I ├
└───┘└───┘
P(2) = 0.0475, Circuit =
┌───┐┌───┐
q: ┤ I ├┤ Z ├
└───┘└───┘
P(3) = 0.9025, Circuit =
┌───┐┌───┐
q: ┤ I ├┤ I ├
└───┘└───┘
# Tensor product two bit-flip and phase-flip errors with
# bit-flip on qubit-0, phase-flip on qubit-1
error2 = phase_flip.tensor(bit_flip)
print(error2)
QuantumError on 2 qubits. Noise circuits:
P(0) = 0.0025000000000000005, Circuit =
┌───┐
q_0: ┤ X ├
├───┤
q_1: ┤ Z ├
└───┘
P(1) = 0.0475, Circuit =
┌───┐
q_0: ┤ I ├
├───┤
q_1: ┤ Z ├
└───┘
P(2) = 0.0475, Circuit =
┌───┐
q_0: ┤ X ├
├───┤
q_1: ┤ I ├
└───┘
P(3) = 0.9025, Circuit =
┌───┐
q_0: ┤ I ├
├───┤
q_1: ┤ I ├
└───┘
Перетворити до та з операторів QuantumChannel
Можна також перетворювати між об'єктами QuantumError у Qiskit Aer та об'єктами QuantumChannel у Qiskit і навпаки.
# Convert to Kraus operator
bit_flip_kraus = Kraus(bit_flip)
print(bit_flip_kraus)
Kraus([[[-9.74679434e-01+0.j, 0.00000000e+00+0.j],
[ 0.00000000e+00+0.j, -9.74679434e-01+0.j]],
[[ 0.00000000e+00+0.j, 2.23606798e-01+0.j],
[ 2.23606798e-01+0.j, -4.96506831e-17+0.j]]],
input_dims=(2,), output_dims=(2,))
# Convert to Superoperator
phase_flip_sop = SuperOp(phase_flip)
print(phase_flip_sop)
SuperOp([[1. +0.j, 0. +0.j, 0. +0.j, 0. +0.j],
[0. +0.j, 0.9+0.j, 0. +0.j, 0. +0.j],
[0. +0.j, 0. +0.j, 0.9+0.j, 0. +0.j],
[0. +0.j, 0. +0.j, 0. +0.j, 1. +0.j]],
input_dims=(2,), output_dims=(2,))
# Convert back to a quantum error
print(QuantumError(bit_flip_kraus))
# Check conversion is equivalent to original error
QuantumError(bit_flip_kraus) == bit_flip
QuantumError on 1 qubits. Noise circuits:
P(0) = 1.0, Circuit =
┌───────┐
q: ┤ kraus ├
└───────┘
True
Помилка зчитування
Класичні помилки зчитування задаються списком векторів імовірностей присвоєння :
- — записане значення класичного біту
- — справжнє значення біту, отримане з вимірювання
Наприклад, для одного кубіту: .
# Measurement misassignment probabilities
p0given1 = 0.1
p1given0 = 0.05
ReadoutError([[1 - p1given0, p1given0], [p0given1, 1 - p0given1]])
ReadoutError([[0.95 0.05]
[0.1 0.9 ]])
Помилки зчитування також можна комбінувати за допомогою compose, tensor та expand, як і квантові помилки.
Додавання помилок до моделі шуму
Коли додаємо квантову помилку до моделі шуму, потрібно вказати тип інструкції, на яку вона діє, та кубіти, до яких її застосовувати. Є два варіанти квантових помилок:
- Помилка для всіх кубітів
- Помилка для конкретних кубітів
1. Помилка для всіх кубітів
Застосовує однакову помилку до кожного входження інструкції, незалежно від того, на які кубіти вона діє.
Додається як noise_model.add_all_qubit_quantum_error(error, instructions):
# Create an empty noise model
noise_model = NoiseModel()
# Add depolarizing error to all single qubit u1, u2, u3 gates
error = depolarizing_error(0.05, 1)
noise_model.add_all_qubit_quantum_error(error, ["u1", "u2", "u3"])
# Print noise model info
print(noise_model)
NoiseModel:
Basis gates: ['cx', 'id', 'rz', 'sx', 'u1', 'u2', 'u3']
Instructions with noise: ['u3', 'u1', 'u2']
All-qubits errors: ['u1', 'u2', 'u3']
2. Помилка для конкретних кубітів
Застосовує помилку до кожного входження інструкції, що діє на зазначений список кубітів. Зверни увагу: порядок кубітів має значення — наприклад, помилка, застосована до кубітів [0, 1] для двокубітного гейту, відрізняється від тієї, що застосована до кубітів [1, 0].
Додається як noise_model.add_quantum_error(error, instructions, qubits):
# Create an empty noise model
noise_model = NoiseModel()
# Add depolarizing error to all single qubit u1, u2, u3 gates on qubit 0 only
error = depolarizing_error(0.05, 1)
noise_model.add_quantum_error(error, ["u1", "u2", "u3"], [0])
# Print noise model info
print(noise_model)
NoiseModel:
Basis gates: ['cx', 'id', 'rz', 'sx', 'u1', 'u2', 'u3']
Instructions with noise: ['u3', 'u1', 'u2']
Qubits with noise: [0]
Specific qubit errors: [('u1', (0,)), ('u2', (0,)), ('u3', (0,))]
Примітка про нелокальні квантові помилки для кубітів
NoiseModel не підтримує додавання нелокальних квантових помилок для кубітів. Їх слід обробляти поза NoiseModel. Це означає, що тобі потрібно написати власний transpiler pass (TransformationPass) і запустити його безпосередньо перед запуском симулятора, якщо ти хочеш вставити свої квантові помилки в схему за власними умовами.