濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > python使用ProjectQ生成量子算法指令集

python使用ProjectQ生成量子算法指令集

熱門(mén)標(biāo)簽:富錦商家地圖標(biāo)注 武漢外呼系統(tǒng)平臺(tái) 沈陽(yáng)外呼系統(tǒng)呼叫系統(tǒng) 沈陽(yáng)人工外呼系統(tǒng)價(jià)格 如何申請(qǐng)400電話(huà)費(fèi)用 外呼系統(tǒng)哪些好辦 江西省地圖標(biāo)注 沈陽(yáng)防封電銷(xiāo)卡品牌 池州外呼調(diào)研線(xiàn)路

輸出算法操作

首先介紹一個(gè)最基本的使用方法,就是使用ProjectQ來(lái)打印量子算法中所輸入的量子門(mén)操作,這里使用到了ProjectQ中的DummyEngine后端用于保存操作的指令。比如最簡(jiǎn)單的一個(gè)Bell State的制備,可以通過(guò)如下代碼實(shí)現(xiàn),并且打印出所保存的基本操作:

from projectq import MainEngine
from projectq.cengines import DummyEngine
from projectq.ops import H, CX, All, Measure

backend = DummyEngine(save_commands=True)
eng = MainEngine(backend=backend)

qureg = eng.allocate_qureg(2)
H | qureg[0]
CX | (qureg[0], qureg[1])

All(Measure) | qureg
eng.flush(deallocate_qubits=True)

for cmd in backend.received_commands:
    print (cmd)

運(yùn)行結(jié)果如下:

Allocate | Qureg[0]
H | Qureg[0]
Allocate | Qureg[1]
CX | ( Qureg[0], Qureg[1] )
Measure | Qureg[0]
Measure | Qureg[1]
Deallocate | Qureg[0]
Deallocate | Qureg[1]

這里有一點(diǎn)需要注意的是,如果是單次運(yùn)算,我們到Measure就可以結(jié)束了。但是如果同一個(gè)線(xiàn)程的任務(wù)還沒(méi)有結(jié)束的話(huà),需要在Measure之后加上一個(gè)deallocate_qubits=True的配置項(xiàng),用于解除當(dāng)前分配的量子比特所占用的內(nèi)存。

封裝的操作

在量子算法的實(shí)現(xiàn)中,我們可以用一些函數(shù)或者類(lèi)來(lái)封裝一部分的量子算法操作指令,但是這可能會(huì)導(dǎo)致一個(gè)問(wèn)題,那就是在ProjectQ上打印出來(lái)的操作指令沒(méi)有把封裝的模塊的內(nèi)容輸出出來(lái),比如如下的案例:

from projectq import MainEngine
from projectq.cengines import DummyEngine
from projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperator

backend = DummyEngine(save_commands=True)
eng = MainEngine(backend=backend)

qureg = eng.allocate_qureg(3)
H | qureg[0]
CX | (qureg[0], qureg[1])
TimeEvolution(1, QubitOperator('X2 X1')) | qureg

All(Measure) | qureg
eng.flush()

for cmd in backend.received_commands:
    print (cmd)

執(zhí)行結(jié)果如下:

Allocate | Qureg[0]
H | Qureg[0]
Allocate | Qureg[1]
CX | ( Qureg[0], Qureg[1] )
Measure | Qureg[0]
Allocate | Qureg[2]
exp(-1j * (1.0 X0 X1)) | Qureg[1-2]
Measure | Qureg[1]
Measure | Qureg[2]

我們發(fā)現(xiàn)這里的含時(shí)演化的操作算符沒(méi)有被分解,而是直接打印輸出了出來(lái)。但是如果在硬件系統(tǒng)中,只能夠識(shí)別支持的指令操作,這里的含時(shí)演化操作可能并未在量子硬件體系中被實(shí)現(xiàn),因此我們就需要在將指令發(fā)送給量子硬件之前,就對(duì)其進(jìn)行分解。

含時(shí)演化算符的分解

這里我們直接調(diào)用ProjectQ的配置中的restrictedgateset方法進(jìn)行操作分解,我們將單比特門(mén)操作的范圍放寬到所有的操作,但是雙比特操作只允許CX操作,并將這個(gè)配置作為engin_list配置到ProjectQ的MainEngine中:

from projectq import MainEngine
from projectq.cengines import DummyEngine
from projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperator
from projectq.setups import restrictedgateset

engine_list = restrictedgateset.get_engine_list(one_qubit_gates="any",two_qubit_gates=(CX,))
backend = DummyEngine(save_commands=True)
eng = MainEngine(backend=backend,engine_list=engine_list)

qureg = eng.allocate_qureg(3)
H | qureg[0]
CX | (qureg[0], qureg[1])
TimeEvolution(1, QubitOperator('X2 X1')) | qureg

All(Measure) | qureg
eng.flush(deallocate_qubits=True)

for cmd in backend.received_commands:
    print (cmd)

打印輸出的結(jié)果如下:

Allocate | Qureg[0]
H | Qureg[0]
Allocate | Qureg[1]
CX | ( Qureg[0], Qureg[1] )
Measure | Qureg[0]
Allocate | Qureg[2]
H | Qureg[2]
H | Qureg[1]
CX | ( Qureg[1], Qureg[2] )
Rz(2.0) | Qureg[2]
CX | ( Qureg[1], Qureg[2] )
H | Qureg[1]
Measure | Qureg[1]
H | Qureg[2]
Measure | Qureg[2]
Deallocate | Qureg[0]
Deallocate | Qureg[1]
Deallocate | Qureg[2]

可以看到含時(shí)演化算符已經(jīng)被分解并輸出了出來(lái)。由于已知單比特量子門(mén)加上一個(gè)CX是一個(gè)完備的量子門(mén)集合,因此一般我們可以直接使用這個(gè)集合來(lái)進(jìn)行量子門(mén)操作指令集的限制。

QFT的分解

QFT是ProjectQ中所自帶支持的量子傅里葉變換的量子門(mén)操作封裝,跟上一個(gè)章節(jié)中所介紹的含時(shí)演化算符類(lèi)似的,我們可以用restrictedgateset來(lái)具體分解QFT算符:

from projectq import MainEngine
from projectq.cengines import DummyEngine
from projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperator, QFT
from projectq.setups import restrictedgateset

engine_list = restrictedgateset.get_engine_list(one_qubit_gates="any",two_qubit_gates=(CX,))
backend = DummyEngine(save_commands=True)
eng = MainEngine(backend=backend,engine_list=engine_list)

qureg = eng.allocate_qureg(3)
H | qureg[0]
CX | (qureg[0], qureg[1])
QFT | qureg

All(Measure) | qureg
eng.flush(deallocate_qubits=True)

for cmd in backend.received_commands:
    print (cmd)

輸出的結(jié)果如下:

Allocate | Qureg[2]
Allocate | Qureg[1]
H | Qureg[2]
Rz(0.785398163398) | Qureg[2]
Allocate | Qureg[0]
H | Qureg[0]
CX | ( Qureg[0], Qureg[1] )
R(0.785398163398) | Qureg[1]
CX | ( Qureg[1], Qureg[2] )
Rz(11.780972450962) | Qureg[2]
CX | ( Qureg[1], Qureg[2] )
R(0.392699081698) | Qureg[0]
Rz(0.392699081698) | Qureg[2]
CX | ( Qureg[0], Qureg[2] )
H | Qureg[1]
Rz(12.173671532661) | Qureg[2]
CX | ( Qureg[0], Qureg[2] )
R(0.785398163398) | Qureg[0]
Rz(0.785398163398) | Qureg[1]
CX | ( Qureg[0], Qureg[1] )
Rz(11.780972450962) | Qureg[1]
CX | ( Qureg[0], Qureg[1] )
H | Qureg[0]
Measure | Qureg[0]
Measure | Qureg[1]
Measure | Qureg[2]
Deallocate | Qureg[1]
Deallocate | Qureg[2]
Deallocate | Qureg[0]

如果2比特門(mén)操作也不加以限制的化,ProjectQ中會(huì)自動(dòng)選取最簡(jiǎn)易的分解形式:

from projectq import MainEngine
from projectq.cengines import DummyEngine
from projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperator, QFT
from projectq.setups import restrictedgateset

engine_list = restrictedgateset.get_engine_list(one_qubit_gates="any",two_qubit_gates="any")
backend = DummyEngine(save_commands=True)
eng = MainEngine(backend=backend,engine_list=engine_list)

qureg = eng.allocate_qureg(3)
H | qureg[0]
CX | (qureg[0], qureg[1])
QFT | qureg

All(Measure) | qureg
eng.flush(deallocate_qubits=True)

for cmd in backend.received_commands:
    print (cmd)

輸出結(jié)果如下:

Allocate | Qureg[0]
Allocate | Qureg[1]
H | Qureg[0]
CX | ( Qureg[0], Qureg[1] )
Allocate | Qureg[2]
H | Qureg[2]
CR(1.570796326795) | ( Qureg[1], Qureg[2] )
CR(0.785398163397) | ( Qureg[0], Qureg[2] )
H | Qureg[1]
CR(1.570796326795) | ( Qureg[0], Qureg[1] )
H | Qureg[0]
Measure | Qureg[0]
Measure | Qureg[1]
Measure | Qureg[2]
Deallocate | Qureg[1]
Deallocate | Qureg[2]
Deallocate | Qureg[0]

可以發(fā)現(xiàn)使用了CR來(lái)替代CX之后,分解出來(lái)的線(xiàn)路會(huì)更加的簡(jiǎn)短。

總結(jié)概要

本文主要從工程實(shí)現(xiàn)的角度,講解在ProjectQ開(kāi)源量子計(jì)算模擬器框架中,實(shí)現(xiàn)量子門(mén)操作分解與輸出的方法。通過(guò)這個(gè)方法,可以限制量子指令集的范圍,將量子算法中不被支持的量子門(mén)操作等價(jià)(或近似地)變化到量子硬件體系所支持的量子指令集上。

以上就是python使用ProjectQ生成量子算法指令集的詳細(xì)內(nèi)容,更多關(guān)于python 用ProjectQ生成算法指令集的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • python 算法題——快樂(lè)數(shù)的多種解法
  • Python機(jī)器學(xué)習(xí)算法之決策樹(shù)算法的實(shí)現(xiàn)與優(yōu)缺點(diǎn)
  • Python集成學(xué)習(xí)之Blending算法詳解
  • python3實(shí)現(xiàn)Dijkstra算法最短路徑的實(shí)現(xiàn)
  • Python實(shí)現(xiàn)K-means聚類(lèi)算法并可視化生成動(dòng)圖步驟詳解
  • Python自然語(yǔ)言處理之切分算法詳解
  • python入門(mén)之算法學(xué)習(xí)
  • Python實(shí)現(xiàn)機(jī)器學(xué)習(xí)算法的分類(lèi)

標(biāo)簽:黑龍江 銅川 呂梁 阿里 潛江 常德 株洲 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python使用ProjectQ生成量子算法指令集》,本文關(guān)鍵詞  python,使用,ProjectQ,生成,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python使用ProjectQ生成量子算法指令集》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于python使用ProjectQ生成量子算法指令集的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    东平县| 中牟县| 吴堡县| 东乌珠穆沁旗| 镇巴县| 安吉县| 中西区| 翁源县| 海城市| 兰州市| 庆元县| 中阳县| 黔东| 阳谷县| 桃园市| 马鞍山市| 保靖县| 绥德县| 晋宁县| 南京市| 台前县| 会泽县| 兴文县| 勐海县| 大新县| 吴川市| 江永县| 建阳市| 南皮县| 曲靖市| 沭阳县| 昔阳县| 甘洛县| 山东省| 康马县| 襄樊市| 盐城市| 从化市| 三穗县| 股票| 通辽市|