はじめに
本日がカレンダ最終日の12/25となります!
当初目標とした、**一通り読めば基礎が身につく!(下記)**ですが、達成度は棚上げしたとして、
量子ゲート、アニーリング共に幅広にいろいろなテーマを扱うことはできた気がします。
量子コンピュータについて一通り読めば基礎が身につくカレンダーを目指します。
- ① 12/01~12/09 :概論や基礎的な内容を整理
- ② 12/10~12/19 :基礎アルゴリズムを整理
- ③ 12/20~12/25 :Tips・ネタ系を掲載
「新たな情報をご紹介する」というよりは、、
「基礎~応用までを体系的に整理」することを目的としている背景で、、
- 特に①や②の一部で、既存記事(公開済み記事)を活用しつつ
- 新たに、必要な内容の整理、新規トピックのまとめを行い
本日は、全25日を振り返ってみたいと思います。
概論
超々概論(12/1)
まずは、初日ですが、コインを使って量子計算のイメージをお伝えしてみました。
雰囲気として伝わっていれば、もしくは、面白そうだなと興味を持っていただければ、
成功だったのですが、いかがでしたでしょうか。
概論(12/2~12/4)
次に3日間かけて、量子コンピュータのハード、ミドル、プラットフォームを整理しました。
特にハードウェアの動向は日々変わっていくので、変化を捉えるのは大変なのですが、最近話題の冷却原子含めリストアップできたのは良かったかなと考えています。
超電導、シリコン、イオントラップ、冷却原子、光、どのデバイスが来るのかは本当に、神のみぞ知る世界かもしれませんが、次のゲームチェンジャの登場に期待しましょうw
量子ゲート型
単一量子ビットの計算(12/5、6)
量子ゲートの計算の基礎を扱いました、行列が出てきたり、色々なゲートが出てきたり大変でしたが、ご理解いただけたでしょうか。
やはり、とっつきにくい分野ですのでご理解頂きやすい様に図等を多用して書いてみたつもりですが、その反面、冗長な記事となってしまった感もありました。
多量子ビットの計算(12/7~12/9)
単一量子ビットの操作の次は、複数量子ビットの計算です。
$CNOT$ゲートを導入したのですが、やはり、$H+CNOT$が揃ったということで、ゲート演算の面白みを感じることができる量子テレポーテーションと、超高密度符号化実験を題材に、複数ビット計算をご理解いただけるよう準備してみました。
数式だけが並ぶときついので、マウス操作でゲートを構成できるQuirkを多用し、記事を書いてみましたが、いかがだったでしょうか?
そして、多量子ビットの計算でなんと言っても外せないのが、位相キックバックです。
このあとのQPE含め、基礎アルゴリズムがこの位相キックバックを用いるため、$CNOT$の制御ビットにどのように、位相がキックバックされるのかを説明してみました。ここでうまくご理解いただければ、このあとのQFT、QPE等にもうまく繋がったかなと考えています。
Long-termアルゴリズム(12/10~12/13)
理想的な量子コンピュータでは、こんな演算ができる!のLong-termアルゴリズムに触れました。
なんと言っても、まずはQFTとQPEからです。
Long-termアルゴリズムの基本ルーチンですので、ご理解いただければ嬉しいです。
次に、ドイチェ/ドイチェ・ジョザ/サイモンのアルゴリズムを説明しました。
一見、退屈なアルゴリズムですが、歴史を知ると不思議と、とても興味深く感じます。
それは、David Deutschの論文に対するRichard Jozsaの反応からも垣間見ることができます。
"It was a funny paper, as it includes brilliant ideas and lots of mistakes"
--- Richard Jozsa
量子計算理論の胎動を感じ、歴史が動き始めたその瞬間が学べるのが、このアルゴリズムではないでしょうか。こんな褒め言葉、ぜひ頂いてみたいものですww
詳細は、「慶応大学 量子コンピュータ授業 #8量子コンピュータの歴史」1 をご確認ください。
とても、面白く、価値ある授業ですので、一度、ご確認いただければと。
そして、量子オラクルを使ってGroverのアルゴリズムに触れました。
Groverを学ぶと、**「神様、最初から答え知っている疑惑」**にぶちあたるのですが、その点にも触れ、$CtrlZ$を用いた最も単純なオラクルで構成する2-bit Grover Serachから発展させ、
Oracle work bitを用い3-bitのGroverと、GroverOperatorの適用回数についても少し考察しました。
もう少し複雑なオラクルの設計については、いつか、また別枠でまとめたいと思います。
最後に、Long-termアルゴリズムの締めくくりとして、Shorのアルゴリズムにふれました。
量子コンピュータが暗号解読につかえるかも?とよく言われますが、その理由は、位数推定問題における求解の優位性にあります。その点を冪剰余の導入から説明させていただきました。
NISQアルゴリズム(12/14~12/16)
次に、NISQ(Noisy Intermediate-Scale Quantum) アルゴリズムです。
古典/量子ハイブリットアルゴリズムで、VQE,QAOA,QCLについてまとめさせて頂きました。
まずは、こちらで、IBM Quantum ChallengeでのVQEの応用例を整理させていただきました。
次に、QAOAの回路を丁寧に構成し、説明させていただきました。
イジングハミルトニアンを如何に構成するかを1量子ビット→2量子ビットと徐々に議論を広げていきました。
最後にQCLです。論文や教科書通りに回路を構成すると、(こちらの考慮漏れか?)うまく学習が進まず、試行錯誤の中で、Z回転ゲートを入れたら、そこそこフィッティング出来たあたりはとてもおもしろかったです。
FTQCに向けて(12/17,18)
***FTQC(Fault Tolerant Quantum Computing)***に向けては、如何に量子系の誤りを訂正し、信頼できる計算を手に入れるか?ですが、本カレンダの中では2つの誤り訂正を扱いました。
1つ目は、Shorの符号です。
ただ、なぜ量子系の誤り訂正が難しのか?をご理解いただく為に、Nielsen & Chuang2が指摘する誤り訂正の困難性について冒頭で触れ、Shorの符号の説明に入っていきました。
ビットフリップ/フェーズフリップ共に訂正するためには9ビット必要である。という衝撃的な事実を知ると共に、連続的な量子エラーも、パウリゲートに分解可能な背景で、測定によりエラーが離散化するという量子誤り訂正の面白い特性にも触れました。
そして、Shorの符号で課題となる、量子ビット増大時の物理状態(符号語)の複雑性に触れ、スタビライザという演算子を用いて物理状態(符号語)を表現するスタビライザ符号について触れました。
説明には、パウリ群、スタビライザ群、スタビライザ群の生成元とスタビライザー状態、検査演算子、シンドローム測定、様々な概念が出てきてしまい、なかなか、理解するのが厳しいのですが、順を追って説明したつもりです。
が、そもそも筆者の理解が足りていない疑惑が濃厚ですので、なにかあればコメントいただければと。
アニーリング(12/19~21)
そして、終盤では、量子アニーリングについて議論をすすめていきました。
まずは、アニーリングにて求解するためには、QUBO問題への帰着と定式化が必要ですので、その方法についてまとめさせていただきました。
比較的簡単な定式化を題材に議論をすすめさせて頂きましたが、ご理解いただけたでしょうか?
次に、実際にD-Waveで求解してみると、ここでも様々な工夫が必要となります。
PyQUBOの利用に始まり、Chain breakとchain strengthの調整、サンプリング回数の調整等、実際に実機を使うにあたって必要な考慮点を整理させて頂きました。
最後にTips系(12/22~24)
最後に応用例として、Fixstars Amplifyを用いて日経225のポートフォリオ最適化を行いました。
ポートフォリオ最適化のコードは、AmplifyのDemoサイトにあるので、日経225のデータロード部分を中心に説明しています。
次に、実際に巡回経路問題と解いてみる。というお題で、こちらは、Fixstars Amplifyを用いて進めさせていただきました。皆さんの身近なところにも最適化問題はひっそり潜んでいるはずですので、是非、そういった身近なテーマで試していただければと思います。
最後の締めくくりとして、
IBM Quantum Challenge Fall 2021の難問だったChallenge 4 の「電池による収益の最適化を断熱量子計算で解く」を、コンテスト後に公開されていた LukasBotschさんのソースコードを参考にしながら読み解くという記事でした。QFT加算器や制約・罰則の与え方あたりがとても勉強になりました。
まとめ
25日間の締めくくりとして、全記事をざーっとまとめてみました。
正直、研究者・専門家にレビュー頂いている訳ではないので、間違いも多いかもしれません。
ただ、量子コンピューティングや並列計算の可能性を感じる、産業界の数人のエンジニアとして、
その可能性や魅力を一般の方に、より分かりやすくお伝えし、何らかかの形で、
量子コンピューティングの堅実かつ健全な成長に、少しでもお役立ちできれば嬉しく思います。
我々の記事は、多くのmistakesを含むと思いますが、brilliantと思えるような議論を
何か一つでも、見つけて頂けたのならば、嬉しく思います。
最後に、Richard Jozsaの言葉を引用し終えたいと思います。
25日間ありがとうございました!(メリー・クリスマス & 良いお年を)
"It was a funny paper, as it includes brilliant ideas and lots of mistakes"
--- Richard Jozsa