亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:41日期:2022-06-19 14:54:23
目錄輸出算法操作封裝的操作含時演化算符的分解QFT的分解總結概要輸出算法操作

首先介紹一個最基本的使用方法,就是使用ProjectQ來打印量子算法中所輸入的量子門操作,這里使用到了ProjectQ中的DummyEngine后端用于保存操作的指令。比如最簡單的一個Bell State的制備,可以通過如下代碼實現,并且打印出所保存的基本操作:

from projectq import MainEnginefrom projectq.cengines import DummyEnginefrom projectq.ops import H, CX, All, Measurebackend = DummyEngine(save_commands=True)eng = MainEngine(backend=backend)qureg = eng.allocate_qureg(2)H | qureg[0]CX | (qureg[0], qureg[1])All(Measure) | quregeng.flush(deallocate_qubits=True)for cmd in backend.received_commands: print (cmd)

運行結果如下:

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]

這里有一點需要注意的是,如果是單次運算,我們到Measure就可以結束了。但是如果同一個線程的任務還沒有結束的話,需要在Measure之后加上一個deallocate_qubits=True的配置項,用于解除當前分配的量子比特所占用的內存。

封裝的操作

在量子算法的實現中,我們可以用一些函數或者類來封裝一部分的量子算法操作指令,但是這可能會導致一個問題,那就是在ProjectQ上打印出來的操作指令沒有把封裝的模塊的內容輸出出來,比如如下的案例:

from projectq import MainEnginefrom projectq.cengines import DummyEnginefrom projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperatorbackend = 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’)) | quregAll(Measure) | quregeng.flush()for cmd in backend.received_commands: print (cmd)

執行結果如下:

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]

我們發現這里的含時演化的操作算符沒有被分解,而是直接打印輸出了出來。但是如果在硬件系統中,只能夠識別支持的指令操作,這里的含時演化操作可能并未在量子硬件體系中被實現,因此我們就需要在將指令發送給量子硬件之前,就對其進行分解。

含時演化算符的分解

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

from projectq import MainEnginefrom projectq.cengines import DummyEnginefrom projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperatorfrom projectq.setups import restrictedgatesetengine_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’)) | quregAll(Measure) | quregeng.flush(deallocate_qubits=True)for cmd in backend.received_commands: print (cmd)

打印輸出的結果如下:

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]

可以看到含時演化算符已經被分解并輸出了出來。由于已知單比特量子門加上一個CX是一個完備的量子門集合,因此一般我們可以直接使用這個集合來進行量子門操作指令集的限制。

QFT的分解

QFT是ProjectQ中所自帶支持的量子傅里葉變換的量子門操作封裝,跟上一個章節中所介紹的含時演化算符類似的,我們可以用restrictedgateset來具體分解QFT算符:

from projectq import MainEnginefrom projectq.cengines import DummyEnginefrom projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperator, QFTfrom projectq.setups import restrictedgatesetengine_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 | quregAll(Measure) | quregeng.flush(deallocate_qubits=True)for cmd in backend.received_commands: print (cmd)

輸出的結果如下:

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比特門操作也不加以限制的化,ProjectQ中會自動選取最簡易的分解形式:

from projectq import MainEnginefrom projectq.cengines import DummyEnginefrom projectq.ops import H, CX, All, Measure, TimeEvolution, QubitOperator, QFTfrom projectq.setups import restrictedgatesetengine_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 | quregAll(Measure) | quregeng.flush(deallocate_qubits=True)for cmd in backend.received_commands: print (cmd)

輸出結果如下:

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]

可以發現使用了CR來替代CX之后,分解出來的線路會更加的簡短。

總結概要

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

以上就是python使用ProjectQ生成量子算法指令集的詳細內容,更多關于python 用ProjectQ生成算法指令集的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 外国毛片视频 | 国产不卡在线视频 | 国产综合精品日本亚洲777 | 欧美日韩国产一区二区三区 | 国产麻豆永久视频 | 欧美夜恋影院夜恋秀场 | 国产精品国内免费一区二区三区 | 97精品在线视频 | 国产亚洲精品成人婷婷久久小说 | 欧美日穴| 曰本一级毛片免费 | 亚洲品质自拍视频 | 在线观看中文字幕第一页 | 播放黄色一级片 | 免费区欧美一级毛片 | 亚洲国产日韩a在线播放 | 在线色片 | 国内精品小视频在线 | 欧美日韩精品一区二区三区视频在线 | 中文字幕不卡免费视频 | 国产欧美日本亚洲精品五区 | 黄色三级毛片视频 | 国产一级特黄在线播放 | 岛国毛片一级一级特级毛片 | 麻豆回家视频区一区二 | 国产区成人综合色在线 | 国产精品又黄又爽又色视频 | 国产a不卡片精品免费观看 国产a毛片高清视 | 午夜色婷婷 | 九九热这里只有国产精品 | 欧美在线观看视频一区 | 3344成年站福利在线视频免费 | 亚洲丝袜在线播放 | 精品视频一区二区三区在线观看 | 日韩大片免费在线观看 | 俄罗斯aa一级毛片 | 国产日产精品_国产精品毛片 | 美腿丝袜国产精品第一页 | 欧美第四页 | 久久九色综合九色99伊人 | 三级黄色片在线播放 |