Postup odeslání okruhu s Cirq do Azure Quantum
Zjistěte, jak odeslat kvantový okruh Cirq pomocí azure-quantum
Python balíčku. Okruhy Cirq můžete odeslat do Azure Quantum pomocí poznámkového bloku Azure Quantum, který má integrovaný azure-quantum
Python balíček nebo z místního počítače.
Další informace najdete v tématu Kvantové obvody.
Požadavky
Podrobnosti o instalaci najdete v tématu Nastavení rozšíření QDK.
Pracovní prostor Azure Quantum ve vašem předplatném Azure Pokud chcete vytvořit pracovní prostor, přečtěte si téma Vytvoření pracovního prostoru Azure Quantum.
Prostředí Python s nainstalovaným Python nástrojem Pip .
VS Code s nainstalovanou sadou Azure Quantum Development KitPython a rozšířeními Jupyter.
Balíček Azure Quantum
azure-quantum
se značkou [cirq] aqsharp
balíčky.ipykernel
python -m pip install --upgrade azure-quantum[cirq] qsharp ipykernel
Poznámka:
Pokud se nerozpoznalo jádro Python Jupyter
ipykernel
, nástroj VS Code vás vyzve k jeho instalaci.
Vytvoření nového poznámkového bloku Jupyter
- Ve VS Code vyberte > Zobrazit příkaz a vyberte Vytvořit: Nový poznámkový blok Jupyter.
- V pravém horním rohu nástroj VS Code rozpozná a zobrazí verzi Python a virtuální Python prostředí vybrané pro poznámkový blok. Pokud máte více Python prostředí, možná budete muset vybrat jádro pomocí nástroje pro výběr jádra v pravém horním rohu. Pokud nebylo zjištěno žádné prostředí, informace o nastavení najdete v poznámkových blocích Jupyter v editoru VS Code .
Načtení požadovaných importů
V první buňce poznámkového bloku spusťte následující kód, který načte požadované importy:
import azure.quantum
from azure.quantum.cirq import AzureQuantumService
Připojení ke službě Azure Quantum
Pokud se chcete připojit ke službě Azure Quantum, bude váš program potřebovat ID prostředku a umístění pracovního prostoru Azure Quantum.
Přihlaste se ke svému účtu Azure, https://portal.azure.com
Vyberte pracovní prostor Azure Quantum a přejděte na Přehled.
Zkopírujte parametry v polích.
Přidejte novou buňku a pomocí informací o účtu vytvořte Workspace
a AzureQuantumService
objekty pro připojení k pracovnímu prostoru Azure Quantum.
workspace = Workspace(
resource_id = "", # Add the resourceID of your workspace
location = "" # Add the location of your workspace (for example "westus")
)
service = AzureQuantumService(workspace)
Zobrazit seznam všech targets
targets()
Pomocí této metody můžete zobrazit seznam všech pracovních prostorůtargets, které můžou spouštět váš okruh, včetně aktuálního času fronty a dostupnosti.
Poznámka:
targets V seznamu nemusí být uvedena všechna data ve vašem pracovním prostoru – tady bude uvedený jenom targets okruh Cirq nebo OpenQASM.
print(service.targets())
[<Target name="quantinuum.qpu.h1-1", avg. queue time=0 s, Degraded>,
<Target name="quantinuum.sim.h1-1sc", avg. queue time=1 s, Available>,
<Target name="quantinuum.sim.h1-1e", avg. queue time=40 s, Available>,
<Target name="ionq.simulator", avg. queue time=3 s, Available>,
<Target name="ionq.qpu.aria-1", avg. queue time=1136774 s, Available>]
Vytvoření jednoduchého okruhu
Dále vytvořte jednoduchý okruh Cirq, který se má spustit. Tento okruh používá druhou odmocninu brány X nativní pro hardwarový systém IonQ.
import cirq
q0, q1 = cirq.LineQubit.range(2)
circuit = cirq.Circuit(
cirq.X(q0)**0.5, # Square root of X
cirq.CX(q0, q1), # CNOT
cirq.measure(q0, q1, key='b') # Measure both qubits
)
print(circuit)
0: ───X^0.5───@───M────────
│ │
1: ───────────X───M────────
Vyberte program, který target chcete spustit.
Spuštění v simulátoru IonQ
Program teď můžete spustit prostřednictvím služby Azure Quantum a získat výsledek. Následující buňka odešle úlohu (do výchozího simulátoru IonQ), která spouští okruh s 100 snímky, čeká na dokončení úlohy a vrátí výsledky.
result = service.run(program=circuit, repetitions=100, target="ionq.simulator")
Tím se cirq.Result
vrátí objekt.
print(result)
b=1001100101100001000011011101000011010100010111100011001000100100010000001110010010101110110000011010, 1001100101100001000011011101000011010100010111100011001000100100010000001110010010101110110000011010
Odhad nákladů na úlohu
Před spuštěním úlohy v QPU byste měli odhadnout, kolik bude stát spuštění.
Nejaktuálnější podrobnosti o cenách najdete v tématu Ceny IonQ nebo vyhledejte svůj pracovní prostor a zobrazte cenové možnosti na kartě Poskytovatel vašeho pracovního prostoru prostřednictvím: aka.ms/aq/myworkspaces.
Spuštění v QPU IonQ
Předchozí úloha se spustila ve výchozím simulátoru "ionq.simulator"
. Můžete ho ale spustit také na hardwarovém procesoru IonQ (QPU (Quantum Processor Unit ). Pokud chcete spustit na QPU IonQ, zadejte "ionq.qpu.aria-1"
jako target
argument:
result = service.run(
program=circuit,
repetitions=100,
target="ionq.qpu.aria-1",
timeout_seconds=500 # Set timeout to accommodate queue time on QPU
)
Opět se vrátí cirq.Result
objekt.
print(result)
b=0101011011011111100001011101101011011110100010000000011110111000100100110110101100110001001111101111, 0101011011011111100001011101101011011110100010000000011110111000100100110110101100110001001111101111
Asynchronní model s využitím úloh
U dlouhotrvajících okruhů může být užitečné je spouštět asynchronně.
Metoda service.create_job
vrátí Job
objekt, který můžete použít k získání výsledků po úspěšném spuštění úlohy.
job = service.create_job(
program=circuit,
repetitions=100,
target="ionq.simulator"
)
Pokud chcete zkontrolovat stav úlohy, použijte job.status()
:
print(job.status())
'completed'
Pokud chcete počkat na dokončení úlohy a pak získat výsledky, použijte blokující volání job.results()
:
result = job.results()
print(result)
00: 0.5
11: 0.5
Všimněte si, že to nevrací cirq.Result
objekt. Místo toho vrátí výsledný objekt, který je specifický pro simulátor IonQ a místo zastřeleného dat používá pravděpodobnosti stavu.
type(result)
cirq_ionq.results.SimulatorResult
Chcete-li tento objekt převést na cirq.Result
objekt, použijte result.to_cirq_result()
:
print(result.to_cirq_result())
b=1110101111111110111000011101011111001100010000001011011101001111001111001101100111010000001100011100, 1110101111111110111000011101011111001100010000001011011101001111001111001101100111010000001100011100
Požadavky
- Účet Azure s aktivním předplatným. Pokud nemáte účet Azure, zaregistrujte se zdarma a zaregistrujte si předplatné s průběžným platbou.
- Pracovní prostor Azure Quantum. Další informace najdete v tématu Vytvoření pracovního prostoru Azure Quantum.
Vytvoření nového poznámkového bloku v pracovním prostoru
- Přihlaste se k webu Azure Portal a vyberte pracovní prostor z předchozího kroku.
- V levém okně vyberte Poznámkové bloky.
- Klikněte na Moje poznámkové bloky a klikněte na Přidat nový.
- Zadejte název souboru, například Cirq.ipynb, a klikněte na Vytvořit soubor.
Když se nový poznámkový blok otevře, automaticky vytvoří kód pro první buňku na základě informací o vašem předplatném a pracovním prostoru.
from azure.quantum import Workspace
workspace = Workspace (
resource_id = "", # Add your resource_id
location = "" # Add your workspace location (for example, "westus")
)
Poznámka:
Pokud není uvedeno jinak, měli byste při vytváření spustit každou buňku, abyste se vyhnuli problémům s kompilací.
Kliknutím na trojúhlou ikonu "přehrát" vlevo od buňky spusťte kód.
Načtení požadovaných importů
Nejprve budete muset importovat další modul.
Kliknutím na + Kód přidejte novou buňku a pak přidejte a spusťte následující kód:
from azure.quantum.cirq import AzureQuantumService
Připojení ke službě Azure Quantum
Dále vytvořte AzureQuantumService
objekt pomocí objektu workspace
z předchozí buňky pro připojení k pracovnímu prostoru Azure Quantum. Přidejte novou buňku s následujícím kódem:
provider = AzureQuantumService(workspace)
Definování jednoduchého okruhu
Dále vytvořte jednoduchý okruh Cirq, který se má spustit. Tento okruh používá druhou odmocninu brány X nativní pro hardwarový systém IonQ.
import cirq
q0, q1 = cirq.LineQubit.range(2)
circuit = cirq.Circuit(
cirq.X(q0)**0.5, # Square root of X
cirq.CX(q0, q1), # CNOT
cirq.measure(q0, q1, key='b') # Measure both qubits
)
print(circuit)
0: ───X^0.5───@───M────────
│ │
1: ───────────X───M────────
Zobrazit seznam všech targets
targets()
Pomocí této metody můžete zobrazit seznam všech pracovních prostorůtargets, které můžou spouštět váš okruh, včetně aktuálního času fronty a dostupnosti.
Poznámka:
targets V seznamu nemusí být uvedena všechna data ve vašem pracovním prostoru – tady bude uvedený jenom targets okruh Cirq nebo OpenQASM.
print("This workspace's targets:")
for target in service.targets():
print(target)
This workspace's targets:
<Target name="quantinuum.qpu.h1-1", avg. queue time=0 s, Degraded>
<Target name="quantinuum.sim.h1-1sc", avg. queue time=1 s, Available>
<Target name="quantinuum.sim.h1-1e", avg. queue time=40 s, Available>
<Target name="ionq.simulator", avg. queue time=3 s, Available>
<Target name="ionq.qpu.aria-1", avg. queue time=1136774 s, Available>
Poznámka:
Úplný seznam target může být pro váš pracovní prostor jiný.
Vyberte program, který target chcete spustit.
Spuštění na simulátoru IonQ
Pokud chcete zkontrolovat okruh před jeho spuštěním na skutečném kvantovém hardwaru, můžete použít simulátor IonQ, ionq.simulator
.
Následující buňka odešle úlohu, která spustí okruh s 100 snímky, počká na dokončení úlohy a vrátí výsledky.
result = service.run(
program=circuit,
repetitions=100,
target="ionq.simulator"
)
Tím se cirq.Result
vrátí objekt.
print(result)
b=1001100101100001000011011101000011010100010111100011001000100100010000001110010010101110110000011010, 1001100101100001000011011101000011010100010111100011001000100100010000001110010010101110110000011010
Výsledky můžete vykreslit v histogramu:
import pylab as pl
pl.hist(result.data)
pl.ylabel("Counts")
pl.xlabel("Result")
Odhad nákladů na úlohu
Před spuštěním úlohy na skutečném kvantovém hardwaru nebo jednotce kvantového zpracování (QPU) byste měli odhadnout, kolik stojí spuštění.
Nejaktuálnější podrobnosti o cenách najdete v tématu Ceny IonQ nebo si v okně Poskytovatelé vašeho pracovního prostoru prohlédněte cenové možnosti. Pokud chcete zobrazit aktuální stav kreditu a využití, vyberte Kredity a kvóty.
Spuštění v QPU IonQ
Předchozí úloha se spustila ve výchozím simulátoru ionq.simulator
. Můžete ho ale spustit také na hardwarovém procesoru IonQ nebo v QPU (Quantum Processor Unit ). Pokud chcete spustit na QPU IonQ, zadejte ionq.qpu.aria-1
jako target
argument:
result = service.run(
program=circuit,
repetitions=100,
target="ionq.qpu.aria-1",
timeout_seconds=500 # Set timeout to accommodate queue time on QPU
)
Poznámka:
Doba potřebná ke spuštění okruhu na QPU závisí na aktuálních časech fronty. Průměrnou dobu target fronty můžete zobrazit výběrem okna Poskytovatelé vašeho pracovního prostoru.
Opět se vrátí cirq.Result
objekt.
print(result)
b=1001100101100001000011011101000011010100010111100011001000100100010000001110010010101110110000011010, 1001100101100001000011011101000011010100010111100011001000100100010000001110010010101110110000011010
Asynchronní model s využitím úloh
U dlouhotrvajících okruhů může být užitečné je spouštět asynchronně.
Metoda service.create_job
vrátí Job
objekt, který můžete použít k získání výsledků po úspěšném spuštění úlohy.
job = service.create_job(
program=circuit,
repetitions=100,
target="ionq.simulator"
)
Pokud chcete zkontrolovat stav úlohy, použijte job.status()
:
print(job.status())
'completed'
Pokud chcete počkat na dokončení úlohy a pak získat výsledky, použijte blokující volání job.results()
:
result = job.results()
print(result)
00: 0.5
11: 0.5
Poznámka:
Funkce job.results()
nevrací cirq.Result
objekt. Místo toho vrátí výsledný objekt, který je specifický pro simulátor IonQ a místo zastřeleného dat používá pravděpodobnosti stavu.
type(result)
cirq_ionq.results.SimulatorResult
Chcete-li tento objekt převést na cirq.Result
objekt, použijte result.to_cirq_result()
:
print(result.to_cirq_result())
b=1110101111111110111000011101011111001100010000001011011101001111001111001101100111010000001100011100, 1110101111111110111000011101011111001100010000001011011101001111001111001101100111010000001100011100
Důležité
Odesílání více okruhů v jedné úloze se v současné době nepodporuje. Jako alternativní řešení můžete volat metodu backend.run
pro asynchronní odeslání každého okruhu a pak načíst výsledky každé úlohy. Příklad:
jobs = []
for circuit in circuits:
jobs.append(backend.run(circuit, shots=N))
results = []
for job in jobs:
results.append(job.result())