common.title

Overview
Service overview
Terms of service

Privacy policy

Contact

Sign in
Sign up
common.title

Google CloudからIonQ量子コンピュータを実行する手順

Tetsuro Tabata

2021/08/13 02:20

Google CloudからIonQ量子コンピュータを実行する手順

§ この記事の目的

blueqat cloudでIonQなどの量子コンピュータ実機を無料で利用できる以下のクーポンが2021年5月末で終了してしまいました。

■無料で量子コンピュータの計算が投げられる10,000クレジットクーポン https://blueqat.com/yuichiro_minato2/285e39f4-727e-4053-9310-c5a4eaedadf4

量子コンピュータ実機を無料で利用する方法の一つに、Google Cloudがあります。
Google Cloudでは初回登録で$300クレジットが付与されるため、その範囲で利用することができます。

blueqat cloudにおいて、あくまで有料ですが、お得に量子コンピュータ実機を利用する方法は以下にもありますが、本記事ではGoogle Cloudからの量子コンピュータ実機の利用方法を見てみたいと思います。

■blueqat API 10000クレジット購入
https://store.blueqat.com/collections/credit/products/blueqat-api-10000%E3%82%AF%E3%83%AC%E3%82%B8%E3%83%83%E3%83%88%E8%B3%BC%E5%85%A5

本記事は令和3年8月4日に書いています。

令和3年6月に米国のIonQ(アイオンキュー)社(https://ionq.com )から、同社のイオントラップ型量子コンピュータをGoogle Cloudを通じて利用できるサービスを提供すると発表がありました。 このシステムの使用方法は英語サイトで公開されており、日本語のガイドはまだないようです。

本記事では同公式サイトの情報をもとに、ガイドに従って実際に動作確認を行ってみたいと思います。

§ 大まかな流れ

IonQ社から、今回の手順のガイド(英語)が公開されています。

■Get started with Google Cloud and IonQ
https://ionq.com/docs/get-started-with-google-cloud

動作確認の大まかな実行手順は以下となります。

▼アカウント登録などの事前準備
1. Google Cloudアカウントの登録
2. IonQ Quantum Cloudの購入と起動
3. API Keyの作成

▼量子計算の実行
4. 量子回路の作成
5. 量子回路をJSON形式に変換
6. 量子計算の実行登録

▼計算結果の確認
7. 量子計算の結果取得
8. コンソール画面による確認

§ 料金体系について

Google Cloudの料金体系に従って、使用料が発生します。
初回登録時は以下の無料試用期間と無料クレジットが付与されます。

 ・90日間、月間上限枠内で各プロダクトを試用できる
・$300分の無料クレジットが付与

ただし、以下のいずれかに該当した場合、無料試用が終了します。
・登録から 90 日が経過した場合
・$300相当のクレジットを使い切った場合

IonQ量子コンピュータに関しての料金は以下となります。
・1回の量子計算(1 job)でおよそJPY 110相当かかる
・1 jobにおいて、1量子ビットゲート計算の場合、1 shotあたりおよそJPY 0.003
・1 jobにおいて、2量子ビットゲート計算の場合、1 shotあたりおよそJPY 0.033
※量子計算では、一般的に一回の計算で複数回shot計算(観測)を行います。
※料金は必ず最新情報(Google Cloud)を確認して下さい。

§ アカウント登録などの事前準備

ガイドに沿って進めます。

1. Google Cloudアカウントの登録

(1-1)Google Cloudのアカウント登録は無料でできます。
まずはアカウント登録を行って下さい。
https://cloud.google.com

image

2. IonQ Quantum Cloudの購入と起動

(2-1)Google Cloudにログイン後、下図のように画面左上のナビゲーションメニューから「マーケットプレイス」を選択します。

image

(2-2)下図の通り、ソリューション検索画面で検索枠に「ionq」と入力し、検索を実行します。

image

(2-3)検索されたIonQ Quantum Cloudをクリックします(下図)。

image

(2-4)下図のような画面が出たら、青色の「SUBSCRIBE」(購入または購読)ボタンをクリックします。

image

(2-5)同意の確認画面が出たら、同意を行って下さい。

(2-6)同意後は以下のような画面になるので、「GO TO PRODUCT PAGE」ボタンをクリックして下さい。

image

(2-7)「SUBSCRIBE」(購入または購読)後のプロダクトトップ画面は以下のような表示になります。購入日の日付が表示されています。また、最新の料金についての情報は「料金」タブを確認して下さい。

image

(2-8)IonQプロダクト画面を起動するために「プロバイダで管理」ボタンを選択します。

(2-9)警告画面が出たら「OK」を選択します。

image

(2-10)以下のようなIonQプロダクト画面が表示されたらOKです。

image

3. API Keyの作成

(3-1)API Keyを作成するために、右上のアイコンから「API Keys」を選択しクリックします。

image

(3-2)「Give your key a descriptive name」にAPI Keyの名前を入力し、「Generate key」をクリックします。

image

(3-3)API Keyを作成すると、下図の赤枠部分のように作成したAPI Keyが表示されます。

image

§ 量子計算の実行

これまでの準備が整いましたら、実際に量子計算を実行してみます。

4. 量子回路の作成

(4-1)ガイドによると、GHZ状態の量子回路を作成する例が書かれていますが、ここではまずより易しい量子回路である量子もつれ(エンタングルメント)状態回路を動作確認したいと思います。

量子もつれ(エンタングルメント)状態回路は以下のようになります。

image

5. 量子回路をJSON形式に変換

(5-1) (4-1)で作成した量子回路をJSON形式に置き換えます。 JSONデータは以下としました。

(5-2)さらに(5-1)にいくつかの情報を追加します。
ガイドによると以下の情報を追加しています。

 ・データ形式(言語形式):json
・ショット回数:100
・量子計算jobの名前:entangle-test
・ターゲット(機種):"qpu" (シミュレータの場合は"simulator")

新たに上記を含めたjsonファイルを作成し、「entangle-test.json」として保存します。

6. 量子計算の実行登録

(6-1)まずは、作成したAPI Keyを取得します。(3-3)で表示されているAPI Keyの「Show」ボタンをクリックします。

image

下図のように示された部分がAPI Keyです。

image

(6-2)前手順で作成したjsonファイルをもとに、IonQの量子計算APIサーバに対して量子計算jobを実行します。
ガイドの例では、curlコマンドで実行する例が示されています。以下のようなコマンドで量子計算jobを実行します。

※[API-Key]部分に取得したAPI Keyを設定して下さい。
※jsonファイル名は entangle-test.json としています。

(6-3)curlコマンドを実行すると、IonQの量子計算APIサーバに量子計算jobが登録されます。このときのステータスは「ready」です。 計算の実行は他のjobの実行が終わる順番を待って、自動的に行われます。

jobのステータスは、IonQの画面上の以下の部分に表示されることで確認できます。

image

また、以下のようなcurlコマンドでもステータスを確認することができます。

※[API-Key]部分に取得したAPI Keyを設定して下さい。
※[JOB-ID]部分にjob IDを設定して下さい。job IDはcurlコマンドで量子計算jobを実行したときに表示されます。

§ 計算結果の確認

量子計算jobの登録を行った後、しばらく待つと実行結果が返却されますので、結果の内容を確認します。

7. 量子計算の結果取得

(7-1)量子計算jobが実行されるとステータスが「completed」となります。

image

curlコマンドによる実行結果(緑枠部分)

image

8. コンソール画面による確認

(8-1)さらに、実行結果の詳細を見ることができます。

image

上記の結果を見ると、量子もつれ(エンタングルメント)状態であることが分かります。

© 2024, blueqat Inc. All rights reserved