Quantum Native Dojoは量子コンピュータについて勉強したいと思っている方のために作られた自習教材です。
量子コンピュータの基本的な動作原理から、基礎アルゴリズム、それらを応用してどのように化学計算や金融計算などに役立てるかを学ぶことができます。本教材は誤り訂正の有る量子コンピュータのアルゴリズムの他、数年以内に実用されるであろうNISQ (Noisy Intermidiate-Scale Quantum) デバイスのアルゴリズムもカバーしています。
全ての教材が Jupyter notebook
で製作され、そのまま Google Colaboratory 上で実行可能になっているので、面倒な環境設定をすることなく学習を始めることが可能です。
量子コンピュータは、量子力学の原理に基づいて計算を行います。一方、私達がふだん目にする物理現象は主に古典力学に支配されています。ここに「量子コンピュータは難しい」と思われる原因の一端があります。
Quantum Native Dojoでは、みなさまに量子コンピュータの動作を感覚的に理解して使いこなせるQuantum Nativeになっていただくことを目標としています。Quantum Nativeへの道のりは簡単ではありませんが、このDojoを通して基礎からじっくりと量子力学と量子コンピュータの原理・応用を学ぶことが着実な一歩となるでしょう。
このDojoを巣立ち、Quantum Nativeとなったみなさまが様々な量子アルゴリズム/アプリケーションを作るエンジニアとして活躍されることを期待しています!
Quantum Native Dojoの内容を理解するには、以下のような知識が必要です。
- 複素数とは何か
- 簡単な関数(sin, cos, exp, ...)の微積分
- 行列とベクトルの掛け算、対角化とは何か
基本的に、このレポジトリの"notebook"フォルダ以下にある Jupyter notebook
を読みながら/実行しながら進めていきましょう。
各 Jupyter notebook
は Google Colabolatory
で実行することができるので、自前で環境を構築する必要はありません。
(もちろん、Pythonに詳しい方は手元でnotebookを実行して納得するまで使い倒してください)
-
Google Colabolatory のページを開きます
-
レポジトリのプルダウンで
qulacs/quantum-native-dojo
を選択し、ブランチでmaster
を選択します
- Quantum Native Dojo のリポジトリ をフォークします
- Console から
$ jupyter notebook
でノートブックを起動させます
Jupyter
を起動させるためには Python 3.3
以上と Jupyter
をインストールする必要があります。
また、ノートブックに埋め込まれているコードを実行するためには、numpy
、scipy
、sympy
をインストールする必要があります。
上記のパッケージをまとめてインストールするには anaconda3
のインストールが便利です。
===== 第1部:基礎編 =====
- 量子ビット
- 量子ビットに対する基本演算
- 複数量子ビットの記述
- 回路図の基礎
- コラム:no-cloning theorem, ベルの不等式, CHSH-game
- NISQアルゴリズムとlong-termアルゴリズム
- アダマールテスト
- コラム:量子乱数生成
- 量子フーリエ変換
- 位相推定アルゴリズム(入門編)
- 世界最高速シミュレータQulacsの使い方
- QiskitとIBM Q Experienceの使い方
===== 第2部:NISQ編 =====
- シュレディンガー方程式とは、量子ダイナミクスとは
- トロッター展開を用いた量子シミュレーション
- Variational Quantum Eigensolver (VQE)
- Quantum Circuit Learning
- コラム1: Quantum Circuit Learningを用いた分類
- コラム2: 量子リザーバコンピューティング
- Quantum Approximate Optimization Algorithm (QAOA)
- OpenFermionの使い方
- Qulacs を用いた variational quantum eigensolver (VQE) の実装
- 励起状態の探索手法 (subspace-search variational quantum eigensolver)
===== 第3部:Long-term編 =====
qRAM位相推定アルゴリズム(発展編)実践:位相推定を使った分子の基底状態エネルギー計算Harrow-Hassidim-Lloydアルゴリズムコラム:低ランク行列に対するquantum inspired algorithm
実践:Harrow-Hassidim-Lloydアルゴリズムを用いたポートフォリオ最適化
オラクルアルゴリズムとは何かGroverのアルゴリズムamplitude amplificationamplitude amplificationに基づく量子アルゴリズム
- 古典誤り訂正
- 量子誤り訂正
量子力学・量子コンピュータについてより詳しく知りたい/深く理解したい場合には、以下のような参考書をオススメします。
- 量子力学について:
- 清水明「量子論の基礎 - その本質のやさしい理解のために」、サイエンス社 (2004)
- 量子コンピュータ・量子アルゴリズムについて:
- 竹内 繁樹「量子コンピュータ - 超並列計算のからくり」、講談社 (2005)
また、英語に抵抗がない場合、量子コンピュータの金字塔とも言えるNiesen-Chaungの教科書を読むのがベストです(分量が多いので、時間はかかります)。
- M. Nielsen and I. Chuang, "Quantum Computation and Quantum Information: 10th Anniversary Edition", Cambridge University Press (2010)
本教材について分からないことは以下のコミュニティで聞いてください。
Qulacs Slack Community
本教材は株式会社QunaSysと以下のContributorの方々によって作製・メンテナンスされています。
Keisuke Fujii, kwkbr, MakotoNakai, yoooopeeee, Kosuke Mitarai, Yuya-O-Nakagawa, yamamoto-takahiro
- 2019/4/26: v0.1.0をリリースしました。