メインコンテンツへスキップ

回路

コンピュータサイエンスにおいて、回路とは情報がワイヤを通じてゲートのネットワークに運ばれる計算モデルであり、ゲートはワイヤが運ぶ情報に対する演算を表します。 量子回路は、この一般的な概念に基づいた特定の計算モデルです。

「回路」という言葉は円形の経路を指すことが多いですが、最も一般的に研究されている回路の計算モデルでは、実際には円形の経路は許可されていません。 つまり、回路を計算モデルとして考えるときは、通常非巡回回路を対象とします。 量子回路もこのパターンに従っており、量子回路はフィードバックループを含むことのできない有限の演算シーケンスを表します。

ブール回路

以下は(古典的な)ブール回路の例で、ワイヤは2値を運び、ゲートはブール論理演算を表します:

ブール回路の例

ワイヤ上の情報の流れは左から右へ進みます:図の左側にある X\mathsf{X} および Y\mathsf{Y} というラベルのワイヤは入力ビットであり、それぞれ好きな2値に設定できます。右側のワイヤが出力です。 中間のワイヤは、左から右の順に評価されるゲートによって決まる値を取ります。

ゲートはANDゲート(\wedge とラベル)、ORゲート(\vee とラベル)、NOTゲート(¬\neg とラベル)です。 これらのゲートが計算する関数は多くの読者に馴染みがあるかと思いますが、以下に値の表で示します:

a¬a0110abab000010100111abab000011101111\begin{array}{c} \begin{array}{c|c} a & \neg a\\ \hline 0 & 1\\ 1 & 0\\ \end{array}\\ \\ \\ \end{array} \qquad\quad \begin{array}{c|c} ab & a \wedge b\\ \hline 00 & 0\\ 01 & 0\\ 10 & 0\\ 11 & 1 \end{array} \qquad\quad \begin{array}{c|c} ab & a \vee b\\ \hline 00 & 0\\ 01 & 1\\ 10 & 1\\ 11 & 1 \end{array}

X\mathsf{X}Y\mathsf{Y} の名前のすぐ右にあるワイヤ上の2つの小さな塗りつぶされた円はファンアウト演算を表し、ワイヤ上の値をそのままコピーして複数のゲートへの入力として使えるようにするものです。 ファンアウト演算は、古典的な文脈では常にゲートとして見なされるわけではなく、ある意味で「無料」として扱われることもあります。 しかし、ブール回路を等価な量子回路に変換する際には、ファンアウト演算を明示的にゲートとして分類し、正しく処理・計上する必要があります。

以下は同じ回路を電気工学でよく見られるスタイルで描いたものです。ANDゲート、ORゲート、NOTゲートに慣習的な記号を使用しています:

古典的スタイルのブール回路

このスタイルや特定のゲート記号は以降では使用しませんが、量子回路ではゲートを表す異なる記号を使用します。これらは登場するたびに説明します。

この例の特定の回路は排他的論理和(略してXOR)を計算します。記号 \oplus で表されます:

abab000011101110\begin{array}{c|c} ab & a \oplus b\\ \hline 00 & 0\\ 01 & 1\\ 10 & 1\\ 11 & 0 \end{array}

次の図では入力の1つの選択、X=0\mathsf{X}=0Y=1\mathsf{Y}=1 のみを考えます。 各ワイヤはそれが運ぶ値でラベル付けされているので、演算を追うことができます。 この場合の出力値は 11 であり、XORの正しい値です:01=10 \oplus 1 = 1

ブール回路の評価

他の3つの可能な入力設定も同様の方法で確認できます。

その他の種類の回路

上述のように、コンピュータサイエンスにおける回路の概念は非常に一般的です。 例えば、0011 以外の値を運ぶワイヤを持つ回路や、異なる演算を表すゲートを持つ回路が分析されることがあります。

算術回路では、例えばワイヤが整数値を運び、ゲートが加算や乗算などの算術演算を表します。 次の図は、2つの可変入力値(xxyy)と、値 11 に設定された第3の入力を受け取る算術回路を示しています。 ワイヤが運ぶ値は、xxyy の値の関数として図に示されています。

算術回路の例

また、ゲートが確率的演算を表すような、ランダム性を組み込んだ回路を考えることもできます。

量子回路

量子回路モデルでは、ワイヤは量子ビット(qubit)を表し、ゲートはこれらの量子ビットに対する演算を表します。 ここでは、これまでに登場した演算、すなわちユニタリ演算標準基底測定に焦点を当てます。 他の種類の量子演算や測定について学ぶにつれて、モデルをそれに応じて拡張できます。

以下は量子回路の簡単な例です:

シンプルな量子回路

この回路では、水平線で表される X\mathsf{X} という名前の単一の量子ビットと、この量子ビットに対するユニタリ演算を表すゲートのシーケンスがあります。 上記の例と同様に、情報の流れは左から右に進みます。つまり、最初に行われる演算はアダマール演算、2番目は SS 演算、3番目は再びアダマール演算、そして最後の演算は TT 演算です。 回路全体を適用すると、これらの演算の合成 THSHT H S H が量子ビット X\mathsf{X} に適用されます。

回路の入力状態または出力状態を明示的に示したい場合があります。 例えば、状態 0\vert 0\rangle に演算 THSHT H S H を適用すると、状態 1+i20+121\frac{1+i}{2}\vert 0\rangle + \frac{1}{\sqrt{2}} \vert 1 \rangle が得られます。これは次のように示せます:

評価されたシンプルな量子回路

量子回路は通常、この例のようにすべての量子ビットが 0\vert 0\rangle に初期化された状態で開始しますが、入力量子ビットが最初に異なる状態に設定される場合もあります。 以下は量子回路の別の例で、今度は2つの量子ビットを使います:

eビットを生成する量子回路

いつものように、HH とラベルされたゲートはアダマール演算を指し、2番目のゲートは制御NOTゲートです:塗りつぶされた円は制御量子ビットを表し、\oplus の記号に似た円はターゲット量子ビットを示します。

この回路を詳しく調べてその動作を説明する前に、量子回路における量子ビットの順序付けの規則を明確にすることが不可欠です。 これは、前のレッスンで簡単に触れた、Qiskitがシステムの命名と順序付けに使用する規則と関連しています。

回路における Qiskit の量子ビット順序付け規則

Qiskitでは、回路図において最上部の量子ビットがインデックス 00 を持ち、量子ビットのタプル(またはこのタプルに対応する文字列、直積、テンソル積)の最右端の位置に対応します。上から2番目の量子ビットはインデックス 11 を持ち、タプルの右から2番目の位置に対応します。以降も同様です。最も高いインデックスを持つ最下部の量子ビットは、タプルの最左端の位置に対応します。特に、nn 量子ビット回路における Qiskit のデフォルトの量子ビット名は nn タプル (qn1,,q0)(\mathsf{q_{n-1}},\ldots,\mathsf{q_{0}}) で表され、q0\mathsf{q_{0}} が量子回路図の最上部、qn1\mathsf{q_{n-1}} が最下部の量子ビットです。

これは回路における量子ビット順序付けのより一般的な規則とは逆転しており、混乱の原因になることがよくあります。 この順序付け規則の詳細については、Qiskitにおけるビット順序のドキュメントページをご覧ください。

Qiskitが量子ビットに使用する特定のデフォルト名 q0,,qn1\mathsf{q_{0}},\ldots,\mathsf{q_{n-1}} から逸脱することもありますが、このコース全体を通じて回路図を解釈する際は、上記で説明した順序付け規則に常に従います。 したがって、上記の回路の解釈では、量子ビットの組 (X,Y)(\mathsf{X},\mathsf{Y}) に対する演算を記述しているとなります。 例えば、回路への入力が量子状態 ψϕ\vert\psi\rangle \otimes \vert\phi\rangle である場合、下側の量子ビット X\mathsf{X} が状態 ψ\vert\psi\rangle から始まり、上側の量子ビット Y\mathsf{Y} が状態 ϕ\vert\phi\rangle から始まることを意味します。

回路が何をするかを理解するために、左から右にその演算を追っていきましょう。

  1. 最初の演算は Y\mathsf{Y} に対するアダマール演算です:

    eビット生成回路の最初の演算

    このように単一の量子ビットにゲートを適用する場合、他の量子ビット(この場合は1つだけ)には何も起こりません。何も起こらないことは恒等演算が実行されることと同等です。したがって、上の図の点線の矩形はこの演算を表します:

    IH=(121200121200001212001212). \mathbb{I}\otimes H = \begin{pmatrix} \frac{1}{\sqrt{2}} & \frac{1}{\sqrt{2}} & 0 & 0\\[2mm] \frac{1}{\sqrt{2}} & -\frac{1}{\sqrt{2}} & 0 & 0\\[2mm] 0 & 0 & \frac{1}{\sqrt{2}} & \frac{1}{\sqrt{2}}\\[2mm] 0 & 0 & \frac{1}{\sqrt{2}} & -\frac{1}{\sqrt{2}} \end{pmatrix}.

    テンソル積の左側に恒等行列があり、右側に HH があることに注意してください。これは Qiskit の順序付け規則と一致しています。

  2. 2番目の演算は制御NOTゲートであり、Y\mathsf{Y} が制御、X\mathsf{X} がターゲットです:

    eビット生成回路の2番目の演算

    制御NOTゲートの標準基底状態に対する作用は次の通りです:

    制御NOTゲート

    量子ビットを (X,Y)(\mathsf{X}, \mathsf{Y}) の順に並べ、X\mathsf{X} が回路の下側、Y\mathsf{Y} が上側であることを踏まえると、制御NOTゲートの行列表現は次のようになります:

    (1000000100100100). \begin{pmatrix} 1 & 0 & 0 & 0\\[2mm] 0 & 0 & 0 & 1\\[2mm] 0 & 0 & 1 & 0\\[2mm] 0 & 1 & 0 & 0 \end{pmatrix}.

回路全体が実装するユニタリ演算(UU と呼びます)は、各演算の合成です:

U=(1000000100100100)(121200121200001212001212)=(121200001212001212121200).U = \begin{pmatrix} 1 & 0 & 0 & 0\\[2mm] 0 & 0 & 0 & 1\\[2mm] 0 & 0 & 1 & 0\\[2mm] 0 & 1 & 0 & 0 \end{pmatrix} \begin{pmatrix} \frac{1}{\sqrt{2}} & \frac{1}{\sqrt{2}} & 0 & 0\\[2mm] \frac{1}{\sqrt{2}} & -\frac{1}{\sqrt{2}} & 0 & 0\\[2mm] 0 & 0 & \frac{1}{\sqrt{2}} & \frac{1}{\sqrt{2}}\\[2mm] 0 & 0 & \frac{1}{\sqrt{2}} & -\frac{1}{\sqrt{2}} \end{pmatrix} = \begin{pmatrix} \frac{1}{\sqrt{2}} & \frac{1}{\sqrt{2}} & 0 & 0\\[2mm] 0 & 0 & \frac{1}{\sqrt{2}} & -\frac{1}{\sqrt{2}}\\[2mm] 0 & 0 & \frac{1}{\sqrt{2}} & \frac{1}{\sqrt{2}}\\[2mm] \frac{1}{\sqrt{2}} & -\frac{1}{\sqrt{2}} & 0 & 0 \end{pmatrix}.

特に、ベル状態の表記を思い出すと、

ϕ+=1200+1211ϕ=12001211ψ+=1201+1210ψ=12011210,\begin{aligned} \vert \phi^+ \rangle & = \frac{1}{\sqrt{2}} \vert 0 0 \rangle + \frac{1}{\sqrt{2}} \vert 1 1 \rangle \\[2mm] \vert \phi^- \rangle & = \frac{1}{\sqrt{2}} \vert 0 0 \rangle - \frac{1}{\sqrt{2}} \vert 1 1 \rangle \\[2mm] \vert \psi^+ \rangle & = \frac{1}{\sqrt{2}} \vert 0 1 \rangle + \frac{1}{\sqrt{2}} \vert 1 0 \rangle \\[2mm] \vert \psi^- \rangle & = \frac{1}{\sqrt{2}} \vert 0 1 \rangle - \frac{1}{\sqrt{2}} \vert 1 0 \rangle, \end{aligned}

次のことが分かります:

U00=ϕ+U01=ϕU10=ψ+U11=ψ.\begin{aligned} U \vert 00\rangle & = \vert \phi^+\rangle\\ U \vert 01\rangle & = \vert \phi^-\rangle\\ U \vert 10\rangle & = \vert \psi^+\rangle\\ U \vert 11\rangle & = -\vert \psi^-\rangle. \end{aligned}

したがって、この回路は 00\vert 00\rangle に初期化された2つの量子ビットで実行すると、状態 ϕ+\vert\phi^+\rangle を生成する方法を提供します。 より一般的には、標準基底をベル基底に変換する方法を与えます。 (この例では重要ではありませんが、最後の状態の 1-1 の位相因子、ψ-\vert \psi^-\rangle は、回路に小さな追加を行うことで除去できます。 例えば、回路の最初に制御 ZZ ゲートを追加することができます。これは制御NOTゲートと似ていますが、制御が 11 に設定されているときに、NOTではなく ZZ 演算がターゲット量子ビットに適用されます。 あるいは、最後にスワップゲートを追加することもできます。どちらの選択も、他の3つの標準基底状態に対する回路の動作に影響を与えることなくマイナス符号を除去します。)

一般に、量子回路は任意の数の量子ビットワイヤを含むことができます。また、二重線で示される古典ビットワイヤを含めることもできます。次の例のようになります:

測定を含む回路の例

ここでは、前の例と同様に、2つの量子ビット X\mathsf{X}Y\mathsf{Y} 上のアダマールゲートと制御NOTゲートがあります。 また、2つの古典ビット A\mathsf{A}B\mathsf{B}、および2つの測定ゲートもあります。 測定ゲートは標準基底測定を表します:量子ビットは測定後の状態に変化し、矢印が指す古典ビットに測定結果が上書きされます。

測定を、量子ビットを入力として受け取り古典ビットを出力するゲートとして描くことが便利な場合がよくあります(測定後の状態の量子ビットを出力して結果を別の古典ビットに書き込む代わりに)。 これは、測定された量子ビットが破棄され、その後は安全に無視できることを意味します。その状態は測定結果に応じて 0\vert 0\rangle または 1\vert 1\rangle に変化しています。

例えば、次の回路図は前の図と同じプロセスを表していますが、測定後に X\mathsf{X}Y\mathsf{Y} を無視します:

コンパクトな測定付き回路の例

コースが進むにつれて、量子回路のより多くの例を見ることになります。これらは通常、上記の単純な例よりも複雑です。 以下は回路図によく登場するゲートを示す記号の例です:

  • 単一量子ビットゲートは一般に、演算を示す文字が書かれた正方形として表示されます:

    単一量子ビットゲート

    NOTゲート(または同等の XX ゲート)は、プラス記号を囲んだ円で表されることもあります:

    NOTゲート

  • スワップゲートは次のように表されます:

    スワップゲート

  • 制御ゲート、つまり制御ユニタリ演算を記述するゲートは、制御される演算に縦線でつながれた塗りつぶされた円(制御を示す)で表されます。例えば、制御NOTゲート、制御制御NOTゲート(またはトフォリゲート)、制御スワップゲート(フレドキンゲート)は次のように表されます:

    制御ゲート

  • 複数量子ビットに対する任意のユニタリ演算はゲートとして見なすことができます。それらはユニタリ演算の名前でラベル付けされた矩形で描かれます。例えば、以下は(未指定の)ユニタリ演算 UU をゲートとして描いたもの、およびこのゲートの制御版です:

    任意のユニタリゲートと制御版