複素数ベクトル の離散Fourier変換 は次式で与えられる
量子Fourier変換は正規直交基底 に対して 次の線形オペレータになる。
ゲート を次のように定義する
コンピュータとは、計算をさせる装置である以上、何らかの物理法則にした がっています。 我々の世界を支配している物理法則は相対論的量子力学ですから、この力学 に基づいた計算原理を考える必要があります。 現在の電子コンピュータは、シャノンが示したbool演算を実現する電子回路を 原理として動作しています。 しかし、これらと異なる原理による計算が不可能というわけではありません。 ここでは、量子力学を原理とした計算について紹介します。
量子コンピュータで行う計算も情報処理に違いありませんので、情報の単位 は bit になります。 量子状態でbitを保持できるとします。 量子状態は人間による観測によって確定して、情報を取り出すことができま す。 但し、量子状態は通常は確率的な値になります。つまり 1 bit を表す量子 状態を観測すると、確率 a で 0 が取り 出せ、確率 b で 1 が取り出せる ということになります。 この量子bit(q bit)の実現方法も色々議論されてい ますが、ここでは実現法ではな く、数学モデルについて説明します。
量子状態には、重ね合わせという概念があります。 これは複数の状態が同時に重ね合わさっていて、人間が観測することにより、 一つの状態に収束しそれが観測されるという概念です。 これをコペンハーゲン解釈といいます。
量子力学の問題点を指摘するための、「シュレーディンガーの猫」という思考 実験があります。これは、箱の中に猫を綴じ込め、α線の発生源、 観測器、毒ガス発生器を仕組み、α線が観測されたら毒ガスが発生し、猫が 死ぬように作られた装置を考えます。 一時間以内にα線が観測される確率が 50% であるとします。すると、コペンハーゲ ン解釈によると、箱の中の猫は、生きている猫と死んでいる猫が量子状態で 重ね合わさっていると考えることができます。 この生きている猫と死んでいる猫の重ね合わせの状態というのは、人間の思 考として俄に受け入れがたいものですが、コペンハーゲン解釈ではそう考え るもので、しかも、実際に見ようとすると一つの状態に収束してしまうので、 決して重ね合わせ状態を観測することはできません。
ここで、Dirac の記号を導入します。 行ベクトルを と書き、ブラベクトルと呼びます。 一方、 列ベクトルを と書き、ケットベクトルと呼びます。 すると、内積は と書けます。
さて、量子ビット(q bit) に関しての数学モデルを考えます。0 の状態と 1 の状態をそれぞれ線形代数の位置ベクトルとし、正規直交基底であるとしま す。 0状態の基底を で表し、 1状態の基底を で表すと、これは二次元の正規直交基底なので次が成り立ちます。
これの重ね合わせは と書けます(a,bは複素数)。 状態ベクトルが常に大きさが1であるとすると、 という制約が必要です。 この時、 0, 1 がそれぞれ観測される確率は、 になります。
さて、複数の量子ビットの取扱いをどうするかですが、基本的には同じ考え 方をします。 2 bit の場合、取りうる状態は 00, 01, 10, 11 です。 この 4 状態はそれぞれ別の状態なので、正規直交基底になります。 4次元の正規直交基底なので次のようになります。
これらの状態の重ね合わせを次のように書きます。
つまり、これは4次元単位球の表面の位置ベクトルを意味します。 を観測して、 00, 01, 10, 11 が観測される確率は、それぞれ になります。
このように単純にビット数が増えると、次元が増えます。 これを演算として扱う、テンソル積を導入します。 これは、内積空間 V, W に対して、それぞれの基底が , である時、 の意味は前述した通り、次元を拡張するだけです。
n個の q bit はこの様に2n次元の基底の重ね合わせで表現されます。
さて、この q bit を物理現象に基づいて計算させることを考えます。 これは量子力学に従います。 先ほども述べたように、大きさ 1 で正規化するので、実際にこの量子計算 は q bit に対するユニタリ行列の積になります。
さらに、研究により、複雑なユニタリ行列は以下のような基本的なユニタリ 行列を多次元に拡張(0を挿入)の積で表せることが分かっています。
従って、これらのユニタリ行列と対応した物理現象が起きるような装置を作 成すれば、量子コンピュータが実現できるようになります。 一つのq bit を実現するのに、2次元のベクトルが必要で、 上記のユニタリ行列が2または4次元なので、これは従来のコンピュータの概 念では論理ゲートにあたります。 つまり、ある q bit の列、 に対して上記のユニタリ行列 U1, U2,...,Un があって、 を計算するのに、実際は個々の特定の q bit に対して、上記の定めら れた演算を行う回路のようなものを考えれば良いことになります。
また、複素数 に対して、共役 を で表します。 また、大きさは とします。
行列 に対して、転置行列を で表します。 また、エルミート行列 は で表します。 さらに、単位行列を I としたとき、ユニタリ行列 U は下記を満たす 正方行列です。
一様な磁場の中での陽子などの スピンを考えると、 特定の量子が重ね合わさっている状態で、観測すると 0 の情報か 1 の情報が 得られます。 このように、行列力学的な解釈として現象が二現象の重ね合わせになるような ものをデータの保存を行う単位として選びます。 この時、状態として、二つの現象を区別する単位ベクトルを と とし、これの重ね合わせを計算の単位(1bit)とすることとします。 これを Qbit と呼びます。 φ=φ0 (1,0) + φ1 (0,1) となっているような状態の時、 に対応した現象が実際に観測される確率は、 |φ1^2/(φ1^2+φ2^2) となります。
さらにこの現象が複数存在し、直積的な関係のあるような状況を考える。 つまり、 と の直積 を考える。
最初の2現象と次の2現象に関して、起きうる現象は 最初が で、次が 最初が で、次が など4通りの組み合わせがある。 これに対して、それぞれ単位ベクトルを用意し、 と単位ベクトル同士の直積を定義する。 などと定義します。
これは、 |φ1> = φ10(1,0)+φ11(0,1) |φ2> = φ20(1,0)+φ21(0,1) 単位ベクトル (1,0,0,0), (0,1,0,0), (0,0,1,0), (0,0,0,1) , , , に対し て、
これを |φ1,φ2> と書くと
を意味します。 同様の意味で 以下を |φ1,...,φn> のような表記をします。
n 個の 2x2 の正方行列 について、下記の様に積を定義する。特に をテンソル積と言う。 (n Qbit に対して、 2n 個の計算があることに注意)
量子チューリング機械はテープとして、 Qbit が連続してあるようなものを考 えます。 また、状態遷移関数は δ(p,a,b,q,d)=c という 状態が p, ヘッドが a を読んでいるとき(観測ではなく)、新たに b を書き込 み、状態を q に移し、ヘッドの方向を d に移動する事象の確率振幅を |c|2 と定義する。 このとき、行列 Mδ のc1 行 c2 列は、 c2 から c1 への 1 ステッ プの遷移と対応したδの値になる。 ただし、ここでも Mδ はユニタリ行列になる。
|x> → |1-x>
f(x,y,0)=x,y, x and y
|0> <0| x |0> <0| x I + |0> <0| x |1> <1| x I + |1> <1| x |0> <0| x I + |1> <1| x |1> <1| x (0 1 ; 1 0)
実は、 n Qbit のベクトルに対して、離散フーリエ変換を行ったときの nQbit の関数表は量子多項式時間で求めることができます。
Shor は量子コンピュータを使って、多項式時間で高い確率で、因数分解と、 離散対数問題が解けることを示しました。
yr = 1 mod n となるようなもっとも小さい r を y の mod n のオーダーと言います。 もし、非自明な r が求まると、 n の素因数分解ができます。
関数 f(x) が特定の x=x0 で f(x0)=1 になり、他の x では f(x)=0 となるよ うなことを考えます。