常見的量子閘名稱(包括縮寫)、電路形式以及相應的酉矩陣.
量子閘(或量子邏輯閘)在量子計算和特別是量子線路的計算模型裡面是一個基本的,操作一個小數量量子位元的量子線路。它是量子線路的基礎,就像傳統邏輯閘跟一般數位線路之間的關係。
與多數傳統邏輯閘不同,量子邏輯閘是可逆的。然而,傳統的計算可以只使用可逆的閘表示。舉例來說,可逆的Toffoli閘可以實做所有的布林函數。這個閘有一個直接等同的量子閘,也因此代表量子線路可以類比所有傳統線路的操作。
量子邏輯閘使用么正矩陣表示。就像傳統的邏輯閘一樣,它們是針對一個或兩個位元進行操作,常見的量子邏輯閘也是針對一個或兩個量子位元進行操作。這也代表這一些量子閘可以使用 2 × 2 或者 4 × 4 的么正矩陣表示。
常使用的閘
量子閘常使用矩陣表示,操作K個量子位元的閘可以用2k × 2k的么正矩陣表示。一個閘輸入跟輸出的量子位元數量必須要相等。量子閘的操作可以用代表量子閘的矩陣與代表量子位元狀態的向量作相乘來表示。
在下文中,單個量子位元的向量表示為:
![{\displaystyle v_{0}|0\rangle +v_{1}|1\rangle \rightarrow {\begin{bmatrix}v_{0}\\v_{1}\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/b289531954cf04fe78c0e2bad96dd5aed8c088b3)
而兩個量子位元的向量表示為:
![{\displaystyle v_{00}|00\rangle +v_{01}|01\rangle +v_{10}|10\rangle +v_{11}|11\rangle \rightarrow {\begin{bmatrix}v_{00}\\v_{01}\\v_{10}\\v_{11}\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/4484c304ff6ae9a4a353e26d67dbbb2531085b89)
其中
是代表第一個量子位元處於
態,第二個量子位元處於
態所構成的(兩個量子位元的)量子態的基矢。
阿達馬閘(Hadamard gate)
阿達馬閘是只對一個一個量子位元進行操作的閘。這個閘將基本狀態
變成
,並且將
變成
。這個閘可以以阿達馬矩陣表示:
Graphical representation of Hadamard gate
![{\displaystyle H={\frac {1}{\sqrt {2}}}{\begin{bmatrix}1&1\\1&-1\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/7e9287a85abe3857330f8107df46465f5935c34e)
因為矩陣的每一列正交,
,其中I表示單位矩陣,因此H是一個么正矩陣。
泡利-X閘(Pauli-X gate)
泡利-X閘操作一個量子位元。這個閘相當於經典的邏輯反閘。它將
換成
並且
換成
。這個閘可以以一個泡利X矩陣表示:
![{\displaystyle X={\begin{bmatrix}0&1\\1&0\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/e3c8278cc91ac15827e24462fb8766aecec4deed)
泡利-Y閘(Pauli-Y gate)
泡利-Y閘操作單一個量子位元。這個閘可以以一個泡利Y矩陣表示:
![{\displaystyle Y={\begin{bmatrix}0&-i\\i&0\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/c39556410c86e79cef0beeb7accca0a8c0a8a622)
泡利-Z閘(Pauli-Z gate)
泡利-Z閘操作單一個量子位元。這個閘保留基本狀態
不變並且將
換成
。這個閘可以以一個泡利Z矩陣表示:
![{\displaystyle Z={\begin{bmatrix}1&0\\0&-1\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/15f6f034d6ce82bc61dffa0f15048a6d27353a16)
相位偏移閘(Phase shift gates)
這是一系列操作單一量子位元的閘,它保留基本狀態
並且將
換成
。
![{\displaystyle R(\theta )={\begin{bmatrix}1&0\\0&e^{i\theta }\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/f0f6c484e68e16c85eae9d0c4c33b43a9243df49)
這裡的
代表相位位移。一些常見的例子像是
閘的
,相位閘的的
則等於
而泡利-Z閘的
。
互換閘(Swap gate)
互換閘操作兩個量子位元,可以用以下這個矩陣表示:
![{\displaystyle {\mbox{SWAP}}={\begin{bmatrix}1&0&0&0\\0&0&1&0\\0&1&0&0\\0&0&0&1\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/955898f4d093c1dbeab7a648670598db85d26442)
受控閘(Controlled gates)
Circuit representation of controlled NOT gate
受控閘操作兩個以上的量子位元,其中一個或多個量子位元視為某一些操作的控制位元。舉例來說,受控反閘(CNOT)操作兩個量子位元,第二個量子位元只有在第一個量子位元為
的時候進行NOT操作,否則就保持不變。這個閘可以採以下的矩陣表示:
![{\displaystyle {\mbox{CNOT}}={\begin{bmatrix}1&0&0&0\\0&1&0&0\\0&0&0&1\\0&0&1&0\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/b97953957434699c71c5789db7d8f282cecbcf00)
更普遍地說,如果
是一個操作單一量子位元的閘,採以下這個矩陣表示:
![{\displaystyle U={\begin{bmatrix}x_{00}&x_{01}\\x_{10}&x_{11}\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/60579accff35ae136be3df3c5c83b92d6d7ea390)
則受控-
閘就是操作兩個量子位元的量子閘,以第一個量子位元作為控制。操作基本狀態如下:
Graphical representation of controlled-U gate
![{\displaystyle |00\rangle \mapsto |00\rangle }](https://wikimedia.org/api/rest_v1/media/math/render/svg/da7e976ad12c78afc74cd7cf9beda526022dcaa8)
![{\displaystyle |01\rangle \mapsto |01\rangle }](https://wikimedia.org/api/rest_v1/media/math/render/svg/2125c0107eb3d3b66f83c3be65c9db1a7619fbb0)
![{\displaystyle |10\rangle \mapsto |1\rangle U|0\rangle =|1\rangle \left(x_{00}|0\rangle +x_{10}|1\rangle \right)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/7cf1b919b7bf9127fc271a1609dc9071d394310a)
![{\displaystyle |11\rangle \mapsto |1\rangle U|1\rangle =|1\rangle \left(x_{01}|0\rangle +x_{11}|1\rangle \right)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/67cc96fefe36f00ba297c64764cab8409e51cfca)
受控-
閘可以以矩陣代表如下:
![{\displaystyle {\mbox{C}}(U)={\begin{bmatrix}1&0&0&0\\0&1&0&0\\0&0&x_{00}&x_{01}\\0&0&x_{10}&x_{11}\end{bmatrix}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/716ef0c89a21b1631c004b1a65209370f7105cd4)
Toffoli閘(Toffoli gate)
Circuit representation of Toffoli gate
Toffoli閘是一個操作三個量子位元的,對傳統運算是完備的閘。量子的Toffoli閘是類同的閘,以三個量子位元定義。如果前兩個量子位元是
,則對第三個量子位元進行泡利-X運算,反之則不做操作。這是一個受控閘的範例。既然這個閘是一個傳統邏輯閘的量子類比,因此它可以用一個真值表來完整表示如下:
INPUT
|
OUTPUT
|
0 |
0 |
0 |
0 |
0 |
0
|
0 |
0 |
1 |
0 |
0 |
1
|
0 |
1 |
0 |
0 |
1 |
0
|
0 |
1 |
1 |
0 |
1 |
1
|
1 |
0 |
0 |
1 |
0 |
0
|
1 |
0 |
1 |
1 |
0 |
1
|
1 |
1 |
0 |
1 |
1 |
1
|
1 |
1 |
1 |
1 |
1 |
0
|
也可以將這個閘以像是
to
的操作形容。
萬能量子閘
較不正式地說,一個萬能量子閘的集合,是一個任何量子線路均可以用這一些閘實做出來的集合。也就是說,任何其他的單位操作均可以從這個集合組合出一個有限長度的序列來表示。技術上來說,因為可能的量子閘數目是不可數的,而從有限大的集合取出的有限長度的序列則是可數的,所以不可能達成。為了解決這個問題,我們只要求這一個有限大小的集合可以組合出近似任何量子運算的序列。Solovay–Kitaev theorem保證這一件事情可以有效達成。
一個簡單的,操作兩個量子位元的閘,的萬能量子閘集合是一個阿達馬閘(
),一個相位偏移閘
,和一個受控反閘.
只有單一個量子閘的萬能量子閘集合可以用一個操作三個量子位元的Deutsch閘
建構出來[1],Deutsch閘它的操作如下:
在傳統邏輯線路裡面的萬用算子Toffoli閘可以被簡化成一個Deutsch閘,
,因此代表著所有傳統邏輯線路的操作均可以由量子電腦類比。
歷史
現有量子閘的記號是Barenco et al.以費曼所提出的記號為基礎[2]發明的。[3]
註釋
參考文獻
- M. Nielsen and I. Chuang,Quantum Computation and Quantum Information,Cambridge University Press,2000
參閱
外部連結
- List of QC simulators (頁面存檔備份,存於網際網路檔案館)
- Chapter 2 Quantum Gates (頁面存檔備份,存於網際網路檔案館) из C.P. Williams, «Explorations in Quantum Computing», Texts in Computer Science // Springer-Verlag, 2011, ISBN 978-1-84628-887-6, doi:10.1007/978-1-84628-887-6_2 стр 51-122(英文)
- Yoshihisa Yamamoto, Chapter 3 Quantum gates of «AP 226: Physics of Quantum Information», Lecture Notes // Stanford, Winter 2009(英文)
- Dieter Suter, Joachim Stolze, Chapter 5: Complete set of quantum gates (слайды) из Quantum Computing WS // Technischen Universität Dortmund 2009—2010(英文)
- Markus Schmassmann, [1] (頁面存檔備份,存於網際網路檔案館) // QSIT-Course, ETH Zürich, 17. Oktober 2007(英文)