量子コンピュータの基本 - exp(iA) がユニタリー行列になる理由
§ この記事の目的
量子コンピューティングでは、ハミルトニアン・エンコーディングやHHLアルゴリズムなどで逆行列を求める理論において、エルミート行列Aを用いて、e^{iA}がユニタリー行列となることを利用します。
なぜe^{iA}がユニタリー行列になるのか、その理由を確認します。
§ まずは数学の公式の確認
行列や指数関数についての公式を確認します。
公式1 指数行列
n次の正方行列Aに対して、指数行列を以下のように定義する。
e^A = E + A + \frac{1}{2!}A^2+\frac{1}{3!}A^3+...\\
=\sum_{h=0}^{\infty}\frac{1}{h!}A^h\quad(公式1)
公式2 行列の対角化
エルミート行列Aに対して、ユニタリー行列Vを用いて以下のように対角化できる。
(\Lambdaはラムダと読みます)
(これについては後半で証明します)
A = V\Lambda V^\dagger\quad(公式2)
公式3 ユニタリー行列の性質
ユニタリー行列Vは、以下が成立する。
V^{\dagger}V = VV^\dagger=I\quad(公式3)
公式4 エルミート共役
エルミート共役(複素共役を取り、転置した行列)に関する公式。
(AB)^\dagger = B^\dagger A^\dagger\quad(公式4)
公式5 エルミート行列の性質
エルミート行列は、以下が成立する。
公式6 指数行列
どんな正方行列Aに対しても、以下が成立する。
e^{-A} = (e^A)^{-1}\quad(公式6)
§ ユニタリー行列となることの確認
(公式1)を用いるとe^{iA}は、
\begin{align}
e^{iA}&=\sum_{h=0}^{\infty}\frac{1}{h!}(iA)^h\\
&=\sum_{h=0}^{\infty}\frac{i^h}{h!}(A)^h\quad(式1)
\end{align}
と書けます。
ここで、(公式2)を用いて、(式1)のAへ代入します。
\begin{align}
(式1)&=\sum_{h=0}^{\infty}\frac{i^h}{h!}(V\Lambda V^{\dagger})^h\\
&=\sum_{h=0}^{\infty}\frac{i^h}{h!}(V\Lambda V^{\dagger})(V\Lambda V^{\dagger})(V\Lambda V^{\dagger})...\quad(式2)
\end{align}
(式2)
(V\Lambda V^{\dagger})(V\Lambda V^{\dagger})(V\Lambda V^{\dagger})...\\
=V\Lambda(V^{\dagger} V)\Lambda(V^{\dagger} V)\Lambda(V^{\dagger} V)...\\
=V\Lambda^hV^\dagger
よって、(式2)は
\begin{align}
(式2)&=\sum_{h=0}^{\infty}\frac{i^h}{h!}(V\Lambda^h V^{\dagger})\\
&=V\bigg(\sum_{h=0}^{\infty}\frac{i^h}{h!}\Lambda^h\bigg) V^{\dagger}\quad(式3)
\end{align}
ここで、(公式1)より以下が導けるため、
\sum_{h=0}^{\infty}\frac{i^h}{h!}\Lambda^h = e^{i\Lambda}
これを(式3)へ用いて、e^{iA}は以下となります。
e^{iA}=Ve^{i\Lambda}V^\dagger\quad(式4)
次に、(式4)の両辺についてエルミート共役を取ります。
(e^{iA})^\dagger = (Ve^{i\Lambda}V^\dagger)^\dagger\quad(式5)
(公式4)
\begin{align}
(右辺)&=(V^\dagger)^\dagger (e^{i\Lambda})^\dagger V^\dagger\\
&=V (e^{i\Lambda})^\dagger V^\dagger
\end{align}
これを用いて、(式5)は以下のように書き直せます。
(e^{iA})^\dagger = V(e^{i\Lambda})^\dagger V^\dagger \quad(式6)
ここで、(式6)の右辺の一つの項(以下)に注目します。
(e^{i\Lambda})^\dagger\quad(式7)
これを求めるために、まず以下の変形を行います。
(公式2)について、両辺のエルミート共役を取ると、
\begin{align}
(A)^\dagger &= (V\Lambda V^\dagger)^\dagger\\
&=(V^\dagger)^\dagger \Lambda^\dagger V^\dagger\\
&=V\Lambda^\dagger V^\dagger\quad(式8)
\end{align}
上記の左辺はエルミート行列なので、(公式5)より以下が成り立ちます。
よって(式8)は、
A = V\Lambda^\dagger V^\dagger
左からV^\daggerを、右からVをかけると、
\begin{align}
V^\dagger A V &= V^\dagger (V\Lambda^\dagger V^\dagger) V\\
&=\Lambda^\dagger\quad(式9)
\end{align}
(式7)
(e^{i\Lambda})^\dagger = \bigg(\sum_{h=0}^{\infty}\frac{i^h}{h!}\Lambda^h\bigg)^\dagger
上記について右辺の意味を考えると、複素共役を取った上で行列を転置することから以下のように書き直せます。
(右辺)=\sum_{h=0}^{\infty}\frac{(-i)^h}{h!}(\Lambda^\dagger)^h
\Lambda^\daggerに(式9)を代入すると
\begin{align}
(右辺)&=\sum_{h=0}^{\infty}\frac{(-i)^h}{h!}(V^\dagger AV)^h\\
&=V^\dagger\bigg(\sum_{h=0}^{\infty}\frac{(-i)^h}{h!}A^h\bigg)V\\
&=V^\dagger(e^{-iA})V
\end{align}
つまり、(式7)は以下のように求められます。
(e^{i\Lambda})^\dagger = V^\dagger(e^{-iA})V
これを用いて(式6)は、
\begin{align}
(e^{iA})^\dagger &= V(e^{i\Lambda})^\dagger V^\dagger\\
&=V\{V^\dagger (e^{-iA})V\}V^\dagger\\
&=(VV^\dagger)(e^{-iA})(VV^\dagger)\\
&=e^{-iA}
\end{align}
ここで、(公式6)を上式の右辺へ適用すると、
(e^{iA})^\dagger = (e^{iA})^{-1}\quad(式10)
ここで、U=e^{iA}とおくと(式10)は以下のように書き換えられます。
U^\dagger = U^{-1}\quad(式11)
このことから、Uはユニタリー行列であることがわかります。
言い換えると、ユニタリー行列は(公式3)を満たすことからUU^\dagger = Iであり、
逆行列U^{-1}はUU^{-1}=Iであることから、U^\dagger=U^{-1}となり、(式11)と同義となります。
§ 公式2 行列の対角化の証明
(公式2)で以下のように書けることを証明してみましょう。
エルミート行列Aに対して、ユニタリー行列Vを用いて以下のように対角化できる
行列Aについて、対角化と言う処理を行います。
対角化する目的は、Aのn乗を計算する際に、計算を容易にするためです。
ここで行列Aはエルミート行列とします。
以下において、行列Aとその固有ベクトル(列ベクトル)を\mathbf{v}、固有値を\lambdaとします。
ここで、重解が無い場合つまり縮退していない場合を前提とすると、
A\mathbf{v}_k = \lambda_k\mathbf{v}_k\quad(k=1,2,3,...)
列ベクトルをまとめて、以下のように書き換えます。
\begin{align}
A(\mathbf{v}_1\:\mathbf{v}_2\:\mathbf{v}_3\:...) &= (\lambda_1\mathbf{v}_1\:\lambda_2\mathbf{v}_2\:\lambda_3\mathbf{v}_3\:...)\\
&=(\mathbf{v}_1\:\mathbf{v}_2\:\mathbf{v}_3\:...)\begin{pmatrix} \lambda_1 & 0 & 0 & ... \\ 0 & \lambda_2 & 0 & ... \\ 0 & 0 & \lambda_3 & ... \\ : & : & : & : \end{pmatrix}
\end{align}
ここで、列ベクトルのまとまりを行列Vとおくと、以下のように書くことができます。
(\Lambdaはラムダと読みます)
AV = V\Lambda\quad(式20)\\
ただし、V=(\mathbf{v}_1\:\mathbf{v}_2\:\mathbf{v}_3\:...)\\
\Lambda = \begin{pmatrix} \lambda_1 & 0 & 0 & ... \\ 0 & \lambda_2 & 0 & ... \\ 0 & 0 & \lambda_3 & ... \\ : & : & : & : \end{pmatrix}
(式20)
(AV)^\dagger = (V\Lambda)^\dagger
左辺、右辺をそれぞれ以下のように計算します。
(左辺) = (AV)^\dagger = V^\dagger A^\dagger\quad(式21)\\
(右辺) = (V\Lambda)^\dagger = \Lambda^\dagger V^\dagger\quad(式22)
Aはエルミート行列なので、以下が成立します。
これを(式21)に代入し、(式22)と等式で結ぶと、
V^\dagger A = \Lambda^\dagger V^\dagger\quad(式23)
さて、(式20)について、左からV^\daggerを掛けると、
V^\dagger AV = V^\dagger V\Lambda\quad(式24)
また、(式23)について、右からVをかけると、
V^\dagger AV = \Lambda^\dagger V^\dagger V\quad(式25)
(式24)
V^\dagger V\Lambda = \Lambda^\dagger V^\dagger V\quad(式26)
\Lambda^\daggerについて内容を確認しておきます。
\Lambdaは(式20)の後半に記載の通りで、これについて複素共役と転置を取ると\Lambda^\daggerになるため、
\Lambda^\dagger = \begin{pmatrix} \lambda_1^* & 0 & 0 & ... \\ 0 & \lambda_2^* & 0 & ... \\ 0 & 0 & \lambda_3^* & ... \\ \vdots & \vdots & \vdots & \ddots \end{pmatrix}\quad(式27)
となります。ここで、*は複素共役を意味します。
(式24)についてi行j列の成分を求めると、
\begin{align}
[V^\dagger V\Lambda]_{ij} \\
&= \begin{bmatrix}
\begin{pmatrix} v_{11}^* & v_{12}^* & v_{13}^* & \ldots \\
v_{21}^* & v_{22}^* & v_{23}^* & \ldots \\
v_{31}^* & v_{32}^* & v_{33}^* & \ldots \\
\vdots & \vdots & \vdots & \ddots \end{pmatrix}
\begin{pmatrix} v_{11} & v_{21} & v_{31} & \ldots \\
v_{12} & v_{22} & v_{32} & \ldots \\
v_{13} & v_{23} & v_{33} & \ldots \\
\vdots & \vdots & \vdots & \ddots \end{pmatrix}
\begin{pmatrix} \lambda_1 & 0 & 0 & \ldots \\
0 & \lambda_2 & 0 & \ldots \\
0 & 0 & \lambda_3 & \ldots \\
\vdots & \vdots & \vdots & \ddots \end{pmatrix}
\end{bmatrix}_{ij}\\
&= \begin{bmatrix}
\begin{pmatrix}
\lambda_1(v_{11}^*v_{11}+v_{12}^*v_{12}+...) & 0 & \ldots \\
0 & \lambda_2(v_{21}^*v_{21}+v_{22}^*v_{22}+...) & \ldots \\
\vdots & \vdots & \ddots
\end{pmatrix} \end{bmatrix}_{ij}\\
&= \sum_{k}^{}\lambda_k(v_{ik}^*v_{ik})\quad(式28)
\end{align}
また、同様に(式25)についてi行j列の成分を求めると、
\begin{align}
[\Lambda^\dagger V^\dagger V]_{ij} \\
&= \begin{bmatrix}
\begin{pmatrix} \lambda_1^* & 0 & 0 & \ldots \\
0 & \lambda_2^* & 0 & \ldots \\
0 & 0 & \lambda_3^* & \ldots \\
\vdots & \vdots & \vdots & \ddots \end{pmatrix}
\begin{pmatrix} v_{11}^* & v_{12}^* & v_{13}^* & \ldots \\
v_{21}^* & v_{22}^* & v_{23}^* & \ldots \\
v_{31}^* & v_{32}^* & v_{33}^* & \ldots \\
\vdots & \vdots & \vdots & \ddots \end{pmatrix}
\begin{pmatrix} v_{11} & v_{21} & v_{31} & \ldots \\
v_{12} & v_{22} & v_{32} & \ldots \\
v_{13} & v_{23} & v_{33} & \ldots \\
\vdots & \vdots & \vdots & \ddots \end{pmatrix}
\end{bmatrix}_{ij}\\
&= \begin{bmatrix}
\begin{pmatrix}
\lambda_1^*(v_{11}^*v_{11}+v_{12}^*v_{12}+...) & 0 & \ldots \\
0 & \lambda_2^*(v_{21}^*v_{21}+v_{22}^*v_{22}+...) & \ldots \\
\vdots & \vdots & \ddots
\end{pmatrix} \end{bmatrix}_{ij}\\
&= \sum_{l}^{}\lambda_l^* (v_{il}^*v_{il})\quad(式29)
\end{align}
(式26)
\sum_{k}^{}\lambda_k(v_{ik}^*v_{ik}) = \sum_{l}^{}\lambda_l^* (v_{il}^*v_{il})\quad(式30)
ここで、固有値が縮退していないことが前提だったため、以下が成立します。
よって、k \neq lの場合に(式30)を満たすのは以下のケースと言えます。
\
v_{ij} = 0\quadただし、i\neq j
一方k=lの場合、
\sum_{k}^{}\lambda_k(v_{ik}^*v_{ik}) = \sum_{k}^{}\lambda_k^* (v_{ik}^*v_{ik})\quad(式31)
上記を満たすには、$ \lambda_i=\lambda_i^* となり、かつ、v_{ii}$は任意の値を取ることができます。
すなわち、以下が導けます。
\Lambda^* = \Lambda\\
Vは対角行列で、大きさは任意に取ることができる
v_{ii}=1とするとVは
V=V^\dagger = \begin{pmatrix} 1 & 0 & 0 & \ldots \\ 0 & 1 & 0 & \ldots \\
0 & 0 & 1 & \ldots \\ \vdots & \vdots & \vdots & \ddots \end{pmatrix} = I
上式から以下が導けます。
さらに、(式24)の右辺を変形すると
\begin{align}
V^\dagger AV &= V^\dagger V\Lambda\\
&= (V^\dagger V)\Lambda\\
&= \Lambda
\end{align}
上式に左からV、右からV^\daggerを掛けると以下が導けます。
以上が証明となります。