(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2024155921
(43)【公開日】2024-10-31
(54)【発明の名称】クラスタ収縮を使用するハイブリッドアルゴリズムのためのシステム及び方法
(51)【国際特許分類】
G06N 10/60 20220101AFI20241024BHJP
【FI】
G06N10/60
【審査請求】有
【請求項の数】12
【出願形態】OL
【外国語出願】
(21)【出願番号】P 2024128231
(22)【出願日】2024-08-02
(62)【分割の表示】P 2021540401の分割
【原出願日】2020-01-13
(31)【優先権主張番号】62/793,694
(32)【優先日】2019-01-17
(33)【優先権主張国・地域又は機関】US
(31)【優先権主張番号】62/841,533
(32)【優先日】2019-05-01
(33)【優先権主張国・地域又は機関】US
(31)【優先権主張番号】62/860,972
(32)【優先日】2019-06-13
(33)【優先権主張国・地域又は機関】US
(71)【出願人】
【識別番号】507209207
【氏名又は名称】ディー-ウェイブ システムズ インコーポレイテッド
(74)【代理人】
【識別番号】100079108
【弁理士】
【氏名又は名称】稲葉 良幸
(74)【代理人】
【識別番号】100109346
【弁理士】
【氏名又は名称】大貫 敏史
(74)【代理人】
【識別番号】100117189
【弁理士】
【氏名又は名称】江口 昭彦
(74)【代理人】
【識別番号】100134120
【弁理士】
【氏名又は名称】内藤 和彦
(72)【発明者】
【氏名】キング,ジェームズ エー.
(72)【発明者】
【氏名】ブースビー,ケリー ティー.アール.
(72)【発明者】
【氏名】ファー ペレス,パウ
(72)【発明者】
【氏名】バーヌーディー,ウィリアム ダブリュー.
(57)【要約】
【課題】 大きく密な入力を、量子プロセッサに容易にマッピングされ得る縮小入力に変換するためにクラスタ収縮を使用するハイブリッド計算システムを動作させるシステム及び方法を提案する。
【解決手段】 縮小入力は、問題のグローバル構造を表す。技法は、入力変数をクラスタに区分けし、且つ各クラスタを収縮させることを伴う。入力変数は、算術平均アルゴリズムを用いる非加重対グループ方法を使用して区分けされ得る。量子プロセッサは、縮小入力に基づいてサンプルを返し、及びサンプルは、元の入力に対応するように拡張される。
【選択図】
図2
【特許請求の範囲】
【請求項1】
量子プロセッサ及び古典プロセッサを含むハイブリッド計算システムの動作の方法であって、
前記古典プロセッサを介して、n個の集団変数を有する入力を有する問題にアルゴリズムを適用することと、
前記古典プロセッサを介して、n個の集団変数を有する前記入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、
前記量子プロセッサを介して、前記縮小入力からのサンプルSrを得ることと、
前記古典プロセッサを介して、前記サンプルSrを拡張して、前記問題への変更状態の組を得ることと
を含む方法。
【請求項2】
前記古典プロセッサを介して、n個の集団変数を有する入力を有する問題にアルゴリズムを適用することは、前記古典プロセッサを介して、n個の集団変数を有する入力を有する問題にパラレルテンパリングアルゴリズムを適用することを含む、請求項1に記載の方法。
【請求項3】
n個の集団変数を有する前記入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することは、前記n個の集団変数をk個のクラスタに区分けし、且つ前記k個のクラスタのそれぞれを収縮させて、k個の集団変数を有する縮小入力を生成することを含む、請求項1又は2に記載の方法。
【請求項4】
前記k個のクラスタのそれぞれを収縮させて、k個の集団変数を有する縮小入力を生成することは、低エネルギー状態sに関して前記k個のクラスタのそれぞれを収縮させて、k個の集団変数を有する縮小入力を生成することを含み、及び前記サンプルSrを拡張して、前記問題への変更状態の組を得ることは、前記低エネルギー状態sに関して前記サンプルSrを拡張して、前記問題への変更状態の組を得ることを含む、請求項3に記載の方法。
【請求項5】
低エネルギー状態sに関して前記k個のクラスタのそれぞれを収縮させることは、各クラスタ内の全ての集団変数を、前記状態sにおけるその値に基づいて互いに対してクランプすることを含む、請求項4に記載の方法。
【請求項6】
低エネルギー状態sに関して前記k個のクラスタのそれぞれを収縮させることは、前記クラスタリングに基づいて新しい状態sを作成することを含む、請求項5に記載の方法。
【請求項7】
前記n個の集団変数をk個のクラスタに区分けすることは、状態の低エネルギーサブセットを使用して前記n個の集団変数をk個のクラスタに区分けすることを含む、請求項3に記載の方法。
【請求項8】
前記k個のクラスタのそれぞれを収縮させることは、各クラスタ内の状態の前記低エネルギーサブセットに関して全ての前記集団変数の前記値を平均化することを含む、請求項7に記載の方法。
【請求項9】
状態の低エネルギーサブセットを使用して前記n個の集団変数をk個のクラスタに区分けすることは、算術平均アルゴリズムを用いる非加重対グループ方法を介して前記n個の集団変数をk個のクラスタに区分けすることを含む、請求項7又は8に記載の方法。
【請求項10】
算術平均アルゴリズムを用いる非加重対グループ方法を介して前記n個の集団変数をk個のクラスタに区分けすることは、距離尺度として対エントロピーを使用して、算術平均アルゴリズムを用いる非加重対グループ方法を介して前記n個の集団変数をk個のクラスタに区分けすることを含む、請求項9に記載の方法。
【請求項11】
前記クラスタリングに基づいて新しい状態sを作成することは、ヒューリスティックソルバを使用して、各クラスタについて新しい状態sを作成することを含む、請求項6に記載の方法。
【請求項12】
前記量子プロセッサを介して、前記縮小入力からのサンプルSrを得ることは、前記量子プロセッサを介して、前記縮小入力からのサンプルSrを得る前に、前記古典プロセッサを介して、前記縮小入力を有する前記問題に埋め込みアルゴリズムを適用することを含む、請求項1~11の何れか一項に記載の方法。
【請求項13】
終了条件が満たされるまで、
前記古典プロセッサを介して、前記問題にアルゴリズムを適用することと、
前記古典プロセッサを介して、n個の集団変数を有する前記入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、
前記量子プロセッサを介して、前記縮小入力からのサンプルSrを得ることと、
前記古典プロセッサを介して、前記サンプルSrを拡張して、前記問題への変更状態の組を得ることと、
前記変更状態を前記問題に統合することと
を反復的に繰り返すことを更に含む、請求項1~12の何れか一項に記載の方法。
【請求項14】
終了条件が満たされたか否かを判断することを更に含む、請求項13に記載の方法。
【請求項15】
終了条件が満たされたか否かを判断することは、前記集団変数の品質の尺度が満たされているか否かを判断することを含む、請求項14に記載の方法。
【請求項16】
量子プロセッサ及び古典プロセッサを含むハイブリッド計算システムであって、前記古典プロセッサは、
n個の集団変数を有する入力を有する問題にアルゴリズムを適用することと、
n個の集団変数を有する前記入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、
前記量子プロセッサから、前記縮小入力からのサンプルSrを得ることと、
前記サンプルSrを拡張して、前記問題への変更状態の組を得ることと
を行うように動作可能である、ハイブリッド計算システム。
【請求項17】
前記アルゴリズムは、パラレルテンパリングアルゴリズムである、請求項16に記載のシステム。
【請求項18】
前記古典プロセッサは、n個の集団変数をk個のクラスタに区分けし、且つ前記k個のクラスタのそれぞれを収縮させて、k個の変数を有する縮小入力を生成するように動作可能である、請求項16又は17に記載のシステム。
【請求項19】
前記k個のクラスタのそれぞれは、低エネルギー状態sに関して収縮され、及び前記サンプルSrは、前記低エネルギー状態sに関して拡張される、請求項18に記載のシステム。
【請求項20】
各クラスタ内の全ての集団変数は、前記状態sにおけるその値に基づいて互いに対してクランプされる、請求項19に記載のシステム。
【請求項21】
前記n個の集団変数は、状態の低エネルギーサブセットを使用してk個のクラスタに区分けされる、請求項18に記載のシステム。
【請求項22】
全ての前記集団変数の前記値は、各クラスタ内の状態の前記低エネルギーサブセットに関して平均化される、請求項21に記載のシステム。
【請求項23】
前記n個の集団変数は、算術平均アルゴリズムを用いる非加重対グループ方法を介してk個のクラスタに区分けされる、請求項21又は22に記載のシステム。
【請求項24】
前記算術平均アルゴリズムを用いる非加重対グループ方法は、距離尺度として対エントロピーを使用する、請求項23に記載のシステム。
【請求項25】
新しい状態sは、前記クラスタリングに基づいて作成される、請求項20に記載のシステム。
【請求項26】
ヒューリスティックソルバは、各クラスタについて新しい状態sを作成するために使用される、請求項25に記載のシステム。
【請求項27】
前記古典プロセッサは、前記量子プロセッサから、前記縮小入力からのサンプルSrを得る前に、埋め込みアルゴリズムを介して、前記縮小入力を有する前記問題を埋め込むように動作可能である、請求項16~26の何れか一項に記載のシステム。
【請求項28】
量子プロセッサ及び古典プロセッサを含むハイブリッド計算システムの動作の方法であって、
前記古典プロセッサを介して、問題の状態sに関して複数の変数変更提案を生成することと、
前記古典プロセッサを介して、前記複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサを介して、前記二次非拘束二元最適化問題を解くことと
を含む方法。
【請求項29】
問題についての複数の変数変更提案を生成することは、二次拘束二元最適化問題及び整数二次プログラミング問題の一方からなる問題についての複数の変数変更提案を生成することを含む、請求項28に記載の方法。
【請求項30】
状態sに関して複数の変数変更提案を生成することは、ランダム状態sに関して問題についての複数の変数変更提案を生成することを含む、請求項28又は29に記載の方法。
【請求項31】
前記古典プロセッサを介して、状態sに関して複数の変数変更提案を生成することは、2つの提案が同じ変数を変更せず、及び3つ以上の提案が前記二次非拘束二元最適化問題の費用関数の項に影響しないように複数の変数変更提案を生成することを含む、請求項28~30の何れか一項に記載の方法。
【請求項32】
前記二次非拘束二元最適化問題を解くことにより、指定された前記複数の変数変更提案の前記サブセットを許容することによって前記状態sを変更し、且つ終了条件が満たされるまで、
前記古典プロセッサを介して、状態sn-1に関して複数の変数変更提案を生成することと、
前記古典プロセッサを介して、前記変数変更提案のサブセットを許容する前記エネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサを介して、前記二次非拘束二元最適化問題を解くことと、
前記二次非拘束二元最適化問題を解くことにより、指定された前記提案の前記サブセットを許容することによって前記状態sn-1を状態snに変更することと
を反復的に繰り返すことを更に含む、請求項28~31の何れか一項に記載の方法。
【請求項33】
終了条件が満たされたか否かを判断することを更に含む、請求項32に記載の方法。
【請求項34】
終了条件が満たされたか否かを判断することは、反復数及び前記状態snが品質の尺度を満たすことの群からの少なくとも1つの条件が満たされたか否かを判断することを含む、請求項33に記載の方法。
【請求項35】
古典プロセッサ及び量子プロセッサを含むハイブリッド計算システムであって、前記古典プロセッサは、
問題の状態sに関して複数の変数変更提案を生成することと、
前記複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサに前記二次非拘束二元最適化問題を解かせることと
を行うように動作可能である、ハイブリッド計算システム。
【請求項36】
前記問題は、二次拘束二元最適化問題及び整数二次プログラミング問題の少なくとも一方である、請求項35に記載のシステム。
【請求項37】
前記状態sは、ランダム状態sである、請求項35又は36に記載のシステム。
【請求項38】
前記古典プロセッサは、2つの提案が同じ変数を変更せず、及び3つ以上の提案が前記二次非拘束二元最適化問題の費用関数の項に影響しないように複数の変数変更提案を生成するように動作可能である、請求項35~37の何れか一項に記載のシステム。
【請求項39】
前記古典プロセッサは、前記二次非拘束二元最適化問題を解くことにより、指定された前記複数の変数変更提案の前記サブセットを許容することによって前記状態sを変更し、且つ終了条件が満たされるまで、
状態sn-1に関して複数の変数変更提案を生成することと、
前記変数変更提案のサブセットを許容する前記エネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサに前記二次非拘束二元最適化問題を解かせることと、
前記二次非拘束二元最適化問題を解くことにより、指定された前記提案の前記サブセトを許容することによって前記状態sn-1を状態snに変更することと
を反復的に繰り返すように更に動作可能である、請求項35~38の何れか一項に記載のシステム。
【請求項40】
前記終了条件が満たされたか否かを判断するように動作可能な前記古典プロセッサを更に含む、請求項39に記載のシステム。
【請求項41】
前記古典プロセッサは、経過した反復数及び前記状態snが品質の尺度を満たすことを含む終了条件の群の1つが満たされたか否かを判断するように動作可能である、請求項40に記載のシステム。
【発明の詳細な説明】
【技術分野】
【0001】
分野
本開示は、概して、量子プロセッサ及び古典プロセッサを利用するハイブリッド計算システムにおいて計算問題を解くためのシステム及び方法に関する。
【背景技術】
【0002】
背景
量子アニーリング
量子アニーリングとは、系の低エネルギー状態、典型的には好ましくは系の基底状態を見つけるために使用され得る計算方法である。方法は、エネルギー状態が低いほど安定するため、自然系が低エネルギー状態に向かう傾向がある基本原理に依拠する。古典アニーリングは、系を低エネルギー状態にガイドするために従来の熱揺らぎを使用するが、量子アニーリングは、古典アニーリングよりもエネルギー最小に正確及び/又は高速に達するための非局在化のソースとして、量子トンネリング等の量子効果を使用し得る。
【0003】
量子プロセッサは、量子アニーリング及び/又は断熱量子計算を実行するように設計され得る。以下:
HE∝A(t)HP+B(t)HD
のように、問題ハミルトニアンに比例する第1の項と、非局在化ハミルトニアンに比例する第2の項との和に比例する進化ハミルトニアンを構築することができ、式中、HEは、進化ハミルトニアンであり、HPは、問題ハミルトニアンであり、HDは、非局在化ハミルトニアンであり、A(t)、B(t)は、進化速度を制御することができる係数であり、典型的には範囲[0,1]内にある。
【0004】
特定の例は、超伝導量子ビットの実施により実現される。
【0005】
マルコフ連鎖モンテカルロ
マルコフ連鎖モンテカルロ(MCMC)とは、例えば、模擬アニーリング、パラレルテンパリング、ポピュレーションアニーリング及び他の技法を含む計算技法のクラスである。マルコフ連鎖は、例えば、確率分布を使用することができない場合に使用され得る。マルコフ連鎖は、一連の離散ランダム変数及び/又は各時間ステップにおいて、状態が前の状態のみに依存するランダムプロセスとして記述され得る。連鎖が十分に長い場合、平均等の連鎖の集約特性は、標的分布の集約特性に一致することができる。
【0006】
マルコフ連鎖は、マルコフ提案プロセス(一般に「更新演算」と呼ばれる)に従った新しい点を提案することにより取得することができる。新しい点は、許容又は拒絶される。新しい点が拒絶される場合、新しい提案がなされる等である。許容される新しい点は、標的分布に確率収束するものである。提案及び許容基準が詳細釣合いを満たし、且つ提案がエルゴード性要件を満たす場合、収束が保証される。更に、提案の許容は、マルコフ連鎖が可逆的である、すなわち連鎖中の状態の閉ループにわたる遷移率の積が何れの方向でも同じであるように行うことができる。可逆的マルコフ連鎖は、詳細釣合いを有するとも言える。典型的には、多くの場合、新しい点は、前の点にとってローカルである。
【0007】
二次非拘束二元最適化問題
二次非拘束二元最適化(QUBO)問題は、従来、コンピュータ科学で使用されている。変数は、1値及び0値に対応する真状態及び偽状態である。
【0008】
QUBO問題は、上対角行列Qを使用して定義され、この行列は、実際の重みのN×N上三角行列であり、xは、関数
【数1】
を最小化する二値変数のベクトルであり、式中、対角項Q
i,iは、線形係数であり、非ゼロ非対角項は、二次係数Q
i,jである。
【0009】
これは、
【数2】
としてより簡潔に表現することができる。
【0010】
スカラー表記では、QUBOとして表現される目的関数は、以下の通りである。
【数3】
【0011】
二次非拘束二元最適化問題は、Qで表現されるもの以外の変数に制約がない点で非拘束である。
【0012】
関連する技術分野の上記の例及びそれに関連する制限は、例示的であることが意図され、網羅的であることを意図されない。関連する技術分野の他の制限は、本明細書を読み、図面を研究した上で当業者に明らかになるであろう。
【発明の概要】
【課題を解決するための手段】
【0013】
概要
ハイブリッド計算システムの動作の方法が記載される。ハイブリッド計算システムは、量子プロセッサ及び古典プロセッサを有する。本方法は、古典プロセッサを介して、n個の集団変数を有する入力を有する問題にアルゴリズムを適用することと、古典プロセッサを介して、n個の集団変数を有する入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、量子プロセッサを介して、縮小入力からのサンプルSrを取得することと、古典プロセッサを介して、サンプルSrを拡張して、問題への変更状態の組を取得することとを含む。古典プロセッサを介して、n個の変数を有する入力を有する問題に適用されるアルゴリズムは、パラレルテンパリングアルゴリズムであり得る。n個の集団変数は、k個のクラスタに区分けされ得、及びk個のクラスタのそれぞれは、収縮されて、k個の集団変数を有する縮小入力を生成し得る。クラスタは、低エネルギー状態sに関して又は可能な場合には低エネルギー状態Scの組に基づいて非決定的に収縮され、且つ拡張されて収縮をアンドゥし得るか、又は可能な場合、行われた収縮、Scで観測される相関又は相互エネルギー及びエネルギー関数f又は各クラスタ内の変数へのfの制約に従って非決定的プロセスで拡張され得る。状態sのクラスタ内の全ての集団変数の値は、互いに関してクランプされて、クラスタを収縮させ得る。n個の集団変数は、状態の低エネルギーサブセットを使用して区分けされ得る。集団変数の値は、各クラスタ内の状態の低エネルギーサブセットに関して平均化されて、k個のクラスタのそれぞれを収縮させ得る。n個の集団変数は、算術平均アルゴリズムを用いる非加重対グループ方法を使用して区分けされ得る。対エントロピーは、算術平均アルゴリズムを用いる非加重対グループ方法における距離尺度として使用され得る。新しい状態sがクラスタリングに基づいて作成されて、k個のクラスタのそれぞれを収縮させ得る。ヒューリスティックソルバは、新しい状態sを作成するために使用され得る。埋め込みアルゴリズムは、量子プロセッサからサンプルを得る前に、縮小入力を有する問題に適用され得る。方法は、終了条件が満たされるまで反復的に繰り返され得る。終了条件は、集団変数の品質の尺度を満たすことであり得る。
【0014】
ハイブリッド計算システムが記載される。ハイブリッド計算システムは、量子プロセッサ及び古典プロセッサを含む。n個の集団変数を有する入力を有する問題にアルゴリズムを適用することと、n個の集団変数を有する入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、量子プロセッサから、縮小入力からのサンプルSrを得ることと、サンプルSrを拡張して、問題への変更状態の組を得ることとを行うように動作可能である古典プロセッサである。アルゴリズムは、パラレルテンパリングアルゴリズムであり得る。古典プロセッサは、n個の集団変数をk個のクラスタに区分けし、且つk個のクラスタのそれぞれを収縮さて、k個の変数を有する縮小入力を生成し得る。k個のクラスタのそれぞれは、低エネルギー状態sに関して又は可能な場合には低エネルギー状態Scの組に基づいて非決定的に収縮し得る。サンプルSrは、拡張されて収縮をアンドゥし得るか、又は可能な場合、行われた収縮、Scで観測される相関又は相互エネルギー及びエネルギー関数f又は各クラスタ内の変数へのfの制約に従って非決定的プロセスで拡張し得る。クラスタ内の全ての集団変数の値は、状態sにおけるその値に基づいて互いに関してクランプされて、クラスタを収縮させ得る。n個の集団変数は、状態の低エネルギーサブセットを使用して区分けし得る。全ての集団変数の値は、各クラスタ内の状態の低エネルギーサブセットに関して平均化し得る。n個の集団変数は、算術平均アルゴリズムを用いる非加重対グループ方法を介してk個のクラスタに区分けし得る。対エントロピーが、算術平均アルゴリズムを用いる非加重対グループ方法における距離尺度として使用され得る。古典プロセッサは、量子プロセッサから、縮小入力からのサンプルSrを得る前に、埋め込みアルゴリズムを介して、縮小入力を有する問題を埋め込むように動作可能であり得る。
【0015】
ハイブリッド計算システムの動作の方法が記載される。ハイブリッド計算システムは、量子プロセッサ及び古典プロセッサを含む。方法は、古典プロセッサを介して、問題の状態sに関して複数の変数変更提案を生成することと、古典プロセッサを介して、複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、量子プロセッサを介して、二次非拘束二元最適化問題を解くこととを含む。問題は、二次拘束二元最適化問題又は整数二次プログラミング問題であり得る。方法は、ランダム状態sに関して問題についての複数の変数変更提案を生成し得る。複数の変数変更問題は、2つの提案が同じ変数を変更せず、及び3つ以上の提案が二次非拘束二元最適化問題の費用関数の項に影響しないようなものであり得る。方法は、二次非拘束二元最適化問題を解くことにより、指定された複数の変数変更提案のサブセットを許容することによって状態sを変更し、且つ終了条件が満たされるまで、古典プロセッサを介して、状態sn-1に関して複数の変数変更提案を生成することと、古典プロセッサを介して、複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、量子プロセッサを介して、二次非拘束二元最適化問題を解くことと、二次非拘束二元最適化問題を解くことにより、指定された提案のサブセットを許容することによって状態sn-1を状態snに変更することとを反復的に繰り返すことを更に含み得る。方法は、終了条件が満たされたか否かを判断することを更に含み得る。終了条件は、反復数及び状態snが品質の尺度を満たすことの一方であり得る。
【0016】
ハイブリッド計算システムが記載される。ハイブリッド計算システムは、古典プロセッサ及び量子プロセッサを含む。問題の状態sに関して複数の変数変更提案を生成することと、複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、量子プロセッサに二次非拘束二元最適化問題を解かせることとを行うように動作可能である古典プロセッサである。問題は、二次拘束二元最適化問題及び整数二次プログラミング問題の一方であり得る。状態sは、ランダム状態sであり得る。古典プロセッサは、2つの提案が同じ変数を変更せず、及び3つ以上の提案が二次非拘束二元最適化問題の費用関数の項に影響しないように複数の変数変更提案を生成するように動作可能であり得る。古典プロセッサは、二次非拘束二元最適化問題を解くことにより、指定された複数の変数変更提案のサブセットを許容することによって状態sを変更し、且つ終了条件が満たされるまで、状態sn-1に関して複数の変数変更提案を生成することと、複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、量子プロセッサに二次非拘束二元最適化問題を解かせることと、二次非拘束二元最適化問題を解くことにより、指定された提案のサブセットを許容することによって状態sn-1を状態snに変更することとを反復的に繰り返すように更に動作可能である。古典プロセッサは、終了条件が満たされたか否かを判断するように更に動作可能であり得る。古典プロセッサは、経過した反復数及び状態snが品質の尺度を満たすことを含む終了条件の群の1つが満たされたか否かを判断するように動作可能であり得る。
【0017】
図面の幾つかの図の簡単な説明
図面中、同一の参照番号は、同様の要素又は動作を識別する。図面中の要素のサイズ及び相対位置は、必ずしも一定の縮尺で描かれているわけではない。例えば、種々の要素の形状及び角度は、必ずしも一定の縮尺で描かれているわけではなく、これらの要素によっては、図面の見やすさを改善するように任意に拡大され、位置決めされていることがある。更に、描かれた要素の特定の形状は、必ずしも、その特定の要素の実際の形状に関する任意の情報を伝達することが意図されるわけではなく、単に図面において認識しやすくするために選択されていることがある。
【図面の簡単な説明】
【0018】
【
図1】量子プロセッサ及び古典プロセッサを有する一例のハイブリッド計算システムの概略図である。
【
図2】クラスタ収縮を使用するハイブリッド計算システムにおける一例の動作方法の流れ図である。
【
図3】クラスタ収縮を使用するハイブリッド計算システムにおける動作の一例の反復方法の流れ図である。
【
図4】クラスタ収縮を使用する古典コンピュータにおける一例の動作方法の流れ図である。
【
図5】クラスタ収縮を使用する古典コンピュータにおける動作の一例の反復方法の流れ図である。
【
図6】古典ソルバ及びクラスタ収縮のポートフォリオを使用するハイブリッド計算システムにおける一例の動作方法の流れ図である。
【
図7】古典ソルバ及びクラスタ収縮のポートフォリオを使用するハイブリッド計算システムにおける動作の一例の反復方法の流れ図である。
【
図8】古典ソルバ及びクラスタ収縮のポートフォリオを使用する古典コンピュータにおける一例の動作方法の流れ図である。
【
図9】古典ソルバ及びクラスタ収縮のポートフォリオを使用する古典コンピュータにおける動作の一例の反復方法の流れ図である。
【
図10】複数の制約ベースの更新を用いるハイブリッド計算システムにおける一例の動作方法の流れ図である。
【
図11】複数の制約ベースの更新を用いるハイブリッド計算システムにおける動作の一例の反復方法の流れ図である。
【
図12】縮約及びそれらの埋め込みを計算するハイブリッド計算システムにおける一例の動作方法の流れ図である。
【発明を実施するための形態】
【0019】
詳細な説明
以下の説明では、種々の開示される実装形態の詳細な理解を提供するために、特定の具体的な詳細が記載される。しかしながら、実装形態が、これらの具体的な詳細の1つ若しくは複数なしで又は他の方法、構成要素、材料等を用いて実施され得ることを当業者は認識するであろう。他の場合、コンピュータシステム、サーバコンピュータ及び/又は通信ネットワークに関連する周知の構造は、実装形態の説明を不必要に曖昧しないように詳細に図示又は記載されない。
【0020】
文脈により別段のことが求められる場合を除き、本明細書及び続く特許請求の範囲全体を通して、用語「含む」は、「包含する」と同義であり、包括的、すなわちオープンエンドである(すなわち追加の記載されていない要素又は方法動作を除外しない)。
【0021】
本明細書全体を通した「一実装形態」又は「実装形態」への言及は、その実装形態と併せて説明された特定の特徴、構造又は特性が少なくとも1つの実装形態に含まれることを意味する。したがって、本明細書全体を通した種々の箇所での句「一実装形態では」又は「実装形態では」の出現は、必ずしも全て同じ実装形態を指すわけではない。更に、1つ又は複数の実装形態では、特定の特徴、構造又は特性は、任意の適した様式で組み合わされ得る。
【0022】
本明細書及び添付の特許請求の範囲全体を通して、用語「サンプル」、「サンプリング」、「サンプル生成器」は、統計及び電気工学の分野での対応する意味を有することが意図される。統計では、サンプルは、集団のサブセットであり、例えば個々のデータ、データ点、オブジェクト又はデータ、データ点若しくはオブジェクトのサブセットである。電気工学では、サンプリングは、物理系、例えばアナログ信号の複数の測定の収集を指す。本明細書及び添付の特許請求の範囲全体を通して、用語「平均」、「平均化」、「平均された」は、統計及び算術の分野における対応する意味を有することが意図されるが、これに限定されない。統計の分野では、平均値は、例えば、平均、メジアン及びモードを指し得る一方、算術の分野では、平均値は、算術平均を指し得る。
【0023】
ハイブリッド計算システムは、アナログプロセッサからサンプルを引き出すことができる。アナログプロセッサは、統計分布からサンプルを提供するように構成することができ、したがってサンプル生成器になることができる。サンプル生成器として動作ことができるプロセッサの一例は、量子アニーリングを実行するように設計された量子プロセッサであり、各サンプルは、プロセッサの状態に対応し、集団は、プロセッサから引き出された状態の組に対応する。
【0024】
本明細書及び添付の特許請求の範囲で使用されるとき、単数形「1つの(a)」、「1つの(an)」及び「その」は、文脈が明らかに別段のことを示す場合を除き、複数形を含む。用語「又は」は、一般に、文脈が明らかに別段のことを示す場合を除き、「及び/又は」を含む意味で利用されることにも留意されたい。
【0025】
本明細書に提供される本開示の見出し及び要約書は、単に便宜を目的とし、実装形態の範囲又は意味を解釈しない。
【0026】
図1は、量子コンピュータ104に結合された古典コンピュータ102を含むハイブリッド計算システム100を示す。一例の古典コンピュータ102は、古典デジタル処理タスクを実行するために使用され得るデジタルプロセッサ(CPU)106を含み、したがって本明細書及び特許請求の範囲では古典プロセッサとして示される。
【0027】
古典コンピュータ102は、少なくとも1つのデジタルプロセッサ(1つ又は複数のコアを有する中央演算処理装置106)、少なくとも1つのシステムメモリ108及びシステムメモリ108を含む種々のシステム構成要素を中央演算処理装置106に結合する少なくとも1つのシステムバス110を含み得る。デジタルプロセッサは、1つ又は複数の中央演算処理装置(「CPU」)、グラフィックス処理ユニット(「GPU」)、デジタル信号プロセッサ(「DSP」)、特定用途向け集積回路(「ASIC」)、プログラマブルゲートアレイ(「FPGA」)、プログラマブル論理コントローラ(PLC)等の任意の論理処理ユニットであり得る。
【0028】
古典コンピュータ102は、ユーザ入出力サブシステム112を含み得る。幾つかの実装形態では、ユーザ入出力サブシステムは、ディスプレイ114、マウス116及び/又はキーボード118等の1つ又は複数のユーザ入出力構成要素を含む。
【0029】
システムバス110は、メモリコントローラを有するメモリバス、周辺バス及びローカルバスを含め、任意の既知のバス構造又はアーキテクチャを利用することができる。システムメモリ108は、読み取り専用メモリ(「ROM」)、静的ランダムアクセスメモリ(「SRAM」)」、フラッシュNANO等の不揮発性メモリ及びランダムアクセスメモリ(「RAM」)等の揮発性メモリ(図示せず)を含み得る。
【0030】
古典コンピュータ102は、他の非一時的コンピュータ若しくはプロセッサ可読記憶媒体又は不揮発性メモリ120を含むこともできる。不揮発性メモリ120は、ハードディスクの読み書きを行うためのハードディスクドライブ、リムーバブル光ディスクの読み書きを行うための光ディスクドライブ及び/又は磁気ディスクの読み書きを行うための磁気ディスクドライブを含め、多様な形態をとり得る。光ディスクは、CD-ROM又はDVDであり得る一方、磁気ディスクは、磁気フロッピーディスク又はディスケットであり得る。不揮発性メモリ120は、システムバス110を介してデジタルプロセッサと通信し得、システムバス110に結合された適切なインターフェース又はコントローラ122を含み得る。不揮発性メモリ120は、プロセッサ若しくはコンピュータ可読命令、データ構造又は古典コンピュータ102の他のデータ(プログラムモジュールと呼ばれることもある)の長期記憶として機能し得る。
【0031】
古典コンピュータ102は、ハードディスク、光ディスク及び/又は磁気ディスクを利用するものとして記載されるが、磁気カセット、フラッシュメモリカード、フラッシュ、ROM、スマートカード等、他のタイプの不揮発性コンピュータ可読媒体が利用され得ることを当業者は理解するであろう。幾つかのコンピュータアーキテクチャは、揮発性メモリ及び不揮発性メモリを利用することを当業者は理解するであろう。例えば、揮発性メモリ内のデータは、不揮発性メモリ又は不揮発性メモリを提供する集積回路を利用する固体状態ディスクにキャッシュすることができる。
【0032】
種々のプロセッサ又はコンピュータ可読命令、データ構造又は他のデータは、システムメモリ108に記憶することができる。例えば、システムメモリ108は、リモートクライアントと通信し、古典コンピュータ102及び量子コンピュータ104でのリソースを含むリソースの使用をスケジュールする命令を記憶し得る。例えば、システムメモリ108は、プロセッサ又はコンピュータ可読命令、データ構造又はプロセッサ若しくはコンピュータによって実行されると、プロセッサ若しくはコンピュータに方法200(
図2)、300(
図3)、400(
図4)、500(
図5)、600(
図6)、700(
図7)、800(
図8)、900(
図9)、1000(
図10)、1100(
図11)及び
図1200(
図12)の動作の1つ、複数又は全てを実行させる他のデータを記憶し得る。
【0033】
幾つかの実装形態では、システムメモリ108は、量子コンピュータ104への事前処理、共同処理及び事後処理を実行するプロセッサ又はコンピュータ可読計算命令を記憶し得る。システムメモリ108は、量子コンピュータ104と対話する組における量子コンピュータインターフェース命令を記憶し得る。
【0034】
量子コンピュータ104は、量子プロセッサ124等の1つ又は複数の量子プロセッサを含み得る。量子コンピュータ104は、分離された環境、例えば量子コンピュータの内部要素を熱、地場及び他の外部ノイズ(図示せず)からシールドする分離された環境に提供することができる。量子プロセッサ124は、量子ビット、カプラ及び他のデバイス等のプログラマブル要素を含む。本開示によれば、量子プロセッサ124等の量子プロセッサは、量子アニーリング及び/又は断熱量子計算を実行するように設計される。量子プロセッサの例は、米国特許第7,533,068号に記載されている。
【0035】
ハイブリッド計算システム、例えばハイブリッド計算システム100は、量子プロセッサのトポロジへのマッピングが難しいか又は適合できない問題に使用され得る。例えば、量子プロセッサの不十分な接続に起因して量子プロセッサに容易にマッピングされない問題の例は、大きく密な入力を有する問題がある。そのような問題は、パラレルテンパリング又は集団ベースの方法(例えば、遺伝アルゴリズム)等のアルゴリズムを使用して古典プロセッサを用いて解くことができる。しかしながら、Houdayer等エネルギークラスタ移動を用いるパラレルテンパリング等の幾つかのアルゴリズムは、疎な入力に適用される場合には強力であるが、密な入力には効率的ではない。現行技法は、クラスタ更新を実行しないか、又は一度に1つのフリップを実行し、したがってクラスタが例えばハード入力の場合に互いに非自明関係を有する場合、非効率的である。
【0036】
したがって、量子プロセッサに適合する入力への量子プロセッサのトポロジよりも大きく及び/又は密な入力を縮小し、ハードでグローバルな構造の問題を提示する技法が必要とされる。本開示に記載のハイブリッドアルゴリズムは、古典リソース(例えば、GPU)を利用して、問題のローカル構造を解き、量子プロセッサを利用して、問題のグローバルでよりハードな構造を解く。
【0037】
問題サイズを低減する手法は、入力変数を、収縮することができるクラスタに区分けし、量子プロセッサで解くことができる縮小入力問題にすることである。変数は、各変数が厳密に1つのクラスタであるように区分けされる。次に、各クラスタは、n個の変数の元の入力をk個の変数の入力に縮小するように収縮し、ここで、nは、非常に大きい数であり得、kは、区画内のクラスタ数である。kの値は、量子プロセッサのトポロジに基づいて選択することができ、例えば、kは、量子プロセッサのトポロジに適合する変数の最大数であり得る。少なくとも1つの実装形態では、kの値は、nに等しい値であり得る。
【0038】
所与の状態s及び変数のk個のクラスタへの区分けの場合、sに対してk個のクラスタをフリップする又はフリップしない2k個の方法がある。フリップするサブセットを見つけることは、k個の変数の縮小入力へのイジング最小化問題に等しく、量子プロセッサで解くことができる。量子プロセッサは、次に、縮小入力に基づいてサンプルの組を生成し、サンプルの組は、sに基づいて又は本明細書に記載の手段を含むが、これに限定されない他の手段に従って拡張することができる。この手法は、純粋に古典的な方法を用いて解くことが難しいことがある問題のグローバル構造を解く強力なマルチクラスタ移動を可能にする。例えば、変数をクラスタに区分けする古典アルゴリズム、例えばリンケージツリー遺伝アルゴリズムは、クラスタに基づく基本更新のみを考慮し、例えばk個のクラスタをフリップすることができる全ての可能な方法を考慮するのではなく、一度に1つのクラスタフリップすることを考慮する。
【0039】
図2は、クラスタ収縮を使用するハイブリッド計算システムの一例の動作方法200の流れ図である。方法200は、量子プロセッサ及び非量子又は古典プロセッサを含むハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行される。
【0040】
方法200は、動作201~208を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0041】
方法200は、例えば、別のルーチンからの呼び出しに応答して、201において開始される。
【0042】
202において、古典プロセッサは、n個の集団変数を有する問題にアルゴリズムを適用する。問題は、201において入力の組の部分として受け取られ得る。少なくとも1つの実装形態では、202において、パラレルテンパリングアルゴリズムが適用される。アルゴリズムは、所定の時間にわたり、例えばn個の集団変数を203において区分けするために有用であり得る状態を生成するのに十分な時間にわたり適用され得る。
【0043】
203において、古典プロセッサは、各変数が厳密に1つのクラスタ内にあるように、n個の集団変数をk個のクラスタに区分けし、ここで、k<nである。少なくとも1つの実装形態では、k≦nである。幾つかの実装形態では、n個の集団変数は、202におけるアルゴリズムの実行から導出された低エネルギー状態Sのサブセットに関して区分けされる。例えば、202においてパラレルテンパリングアルゴリズムが適用された場合、コールデストランダムウォークが直面する状態は、最低エネルギーを有することになり、これらの状態は、n個の集団変数を区分けするように選択される。少なくとも1つの実装形態では、算術平均を用いる非加重対グループ方法(UPGMA)アルゴリズムが使用されて、n個の集団変数をk個のクラスタに区分けする。対相互情報は、UPGMAで使用することができる距離尺度の一例であるが、他の対対象尺度又はスコアを使用することもできる。代替的に、n個の集団変数は、関心のある低エネルギー状態sに関して区分けされる。
【0044】
204において、古典プロセッサは、k個のクラスタのそれぞれを収縮させ、したがって集団変数の数を低減し、202の問題への縮小入力を生成する。幾つかの実装形態では、k≦nである。幾つかの実装形態では、古典プロセッサは、クラスタ内の全ての変数を、状態sに対するその値に基づいてクランプすることにより各クラスタを収縮させ、したがって202の問題への縮小入力を表すk個の変数を得る。状態sは、202において特定され得るか、又は203において特定されるクラスタリングに基づいてヒューリスティックソルバを使用して、古典プロセッサにより作成され得る。代替的に、古典プロセッサは、例えば、各クラスタ内を平均化することにより、サンプリングヒューリスティックを、クラスタに制限されたエネルギー関数に適用することにより、又は状態の組内で観測された相関又は相互譲歩をシミュレートする非決定的アルゴリズムにより、1つの状態sではなく、状態の組に基づいて各クラスタを収縮させる。
【0045】
205において、古典プロセッサは、縮小入力を有する問題を量子プロセッサに送る。幾つかの実装形態では、埋め込みアルゴリズム、例えばマイナー埋め込みは、縮小入力を有する問題に適用されて、量子プロセッサに送ることができる埋め込み問題を生成する。
【0046】
206において、量子プロセッサは、縮小入力からのサンプルSrを返す。
【0047】
207において、古典プロセッサは、サンプルSrを拡張して、n個の集団変数の元の入力に対して変更された新しい状態の組を得る。状態sが204において入力の縮小に使用される場合、サンプルSrは、Srからの状態により示されるクラスタをフリップすることによりsに対して拡張される。幾つかの実装形態では、サンプルSrは、低エネルギー状態の組に基づいて拡張される。これら又は他の実装形態では、拡張は、低エネルギー状態内で観測された統計(相互情報又は相関等)及びエネルギー関数を更に考慮し得る。
【0048】
208において、方法200は、例えば、再び呼び出されるまで終了する。
【0049】
図3は、クラスタ収縮を使用するハイブリッド計算システムの動作の一例の反復方法300の流れ図である。方法300は、量子プロセッサ及び非量子又は古典プロセッサを含むハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行される。
【0050】
方法300は、動作301~310を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0051】
方法300は、例えば、別のルーチンからの呼び出しに応答して、301において開始される。
【0052】
302において、古典プロセッサは、方法200の動作202を参照して上述したように、n個の集団変数を有する問題にアルゴリズムを適用する。
【0053】
303において、古典プロセッサは、方法200の動作203を参照して上述したように、n個の集団変数をk個のクラスタに区分けする。
【0054】
304において、古典プロセッサは、方法200の動作204を参照して上述したように、k個のクラスタのそれぞれを収縮させる。
【0055】
305において、古典プロセッサは、縮小入力を有する問題を量子プロセッサに送る。
【0056】
306において、量子プロセッサは、縮小入力からのサンプルSrを返す。
【0057】
307において、古典プロセッサは、方法200の動作207を参照して上述したように、サンプルSrを拡張する。
【0058】
308において、古典プロセッサは、変更状態をn個の集団変数に統合する。
【0059】
309において、古典プロセッサは、終了条件が満たされたか否かをチェックする。終了条件が満たされた場合、制御は、310に渡り、他の場合、制御は、302に渡り、ここで、アルゴリズムが問題に再び適用される。終了条件は、集団変数の品質の尺度が満たされたか否かを判断することであり得る。
【0060】
310において、方法300は、例えば、再び呼び出されるまで終了する。
【0061】
古典コンピュータは、一般に、量子プロセッサよりも大きい入力サイズを有する問題を解くことができる。しかしながら、非常に大きい入力の場合、古典コンピュータから解を得るまでの時間は、法外に長くなり得る。したがって、古典コンピュータに向けて問題入力サイズを低減する必要がある。上述した方法は、1つの古典コンピュータ又は複数の古典コンピュータを含む古典計算システムを動作させるために利用され得る。更に、ハイブリッド計算システムは、古典コンピュータを使用して上記の方法を利用することができる。
【0062】
問題サイズを縮小する手法は、入力変数を、収縮することができるクラスタに区分けし、量子プロセッサで解くことができる縮小入力問題にすることである。変数は、各変数が厳密に1つのクラスタにあるように区分けされる。次に、各クラスタは、収縮して、n個の変数の元の入力をk個の変数の入力に縮小させ、ここで、nは、非常に大きい数であり得、kは、区画内のクラスタ数である。少なくとも1つの実装形態では、kの値は、nに等しい値であり得る。
【0063】
所与の状態s及び変数のk個のクラスタへの区分けの場合、sに対してk個のクラスタをフリップする又はフリップしない2k個の方法がある。フリップするサブセットを見つけることは、k個の変数の縮小入力へのイジング最小化問題に等しく、古典ソルバを使用して古典プロセッサで解くことができる。古典ソルバ又は古典アルゴリズムという用語は、本開示及び添付の特許請求の範囲では、古典(すなわち非量子)計算リソースのみを使用するソルバ又はアルゴリズムを示すために使用される。使用することができる古典ソルバの例は、パラレルテンパリング及び模擬アニーリングである。古典プロセッサは、次に、縮小入力に基づいてサンプルの組を生成し、サンプルの組は、sに基づいて拡張することができる。他の実装形態では、拡張は、エネルギー関数及び/又は問題解決実行全体を通して観測された統計に部分的に基づき得る。
【0064】
図4は、クラスタ収縮を使用して計算問題を解く一例の方法400の流れ図である。方法400は、少なくとも1つの非量子、すなわち古典プロセッサを含む古典計算システムを介して実行される。代替的に、方法400は、古典プロセッサを使用するハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行することができる。方法400は、動作401~408を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0065】
方法400は、例えば、別のルーチンからの呼び出しに応答して、401において開始される。
【0066】
402において、古典プロセッサは、n個の集団変数を有する問題にアルゴリズムを適用する。問題は、401において入力の組の部分として受け取られ得る。少なくとも1つの実装形態では、402において、パラレルテンパリングアルゴリズムが適用される。アルゴリズムは、所定の時間にわたり、例えばn個の集団変数を403において区分けするために有用であり得る状態を生成するのに十分な時間にわたり適用され得る。
【0067】
403において、古典プロセッサは、各変数が厳密に1つのクラスタ内にあるように、n個の集団変数をk個のクラスタに区分けし、ここで、k<nである。少なくとも1つの実装形態では、k≦nである。幾つかの実装形態では、n個の集団変数は、402におけるアルゴリズムの実行から導出された低エネルギー状態Sのサブセットに関して区分けされる。例えば、402においてパラレルテンパリングアルゴリズムが適用された場合、コールデストランダムウォークが直面する状態は、最低エネルギーを有することになり、これらの状態は、n個の集団変数を区分けするように選択される。少なくとも1つの実装形態では、算術平均を用いる非加重対グループ方法(UPGMA)アルゴリズムが使用されて、n個の集団変数をk個のクラスタに区分けする。対相互情報は、UPGMAで使用することができる距離尺度の一例であるが、他の対対称尺度又はスコアを使用することもできる。代替的に、n個の集団変数は、関心のある低エネルギー状態sに関して区分けされる。
【0068】
404において、古典プロセッサは、k個のクラスタのそれぞれを収縮させ、したがって集団変数の数を低減し、402の問題への縮小入力を生成する。少なくとも1つの実装形態では、k≦nである。幾つかの実装形態では、古典プロセッサは、クラスタ内の全ての変数を、状態sに対するその値に基づいてクランプすることにより各クラスタを収縮させ、したがって402の問題への縮小入力を表すk個の変数を得る。状態sは、402において特定され得るか、又は403において特定されるクラスタリングに基づいてヒューリスティックソルバを使用して、古典プロセッサにより作成され得る。代替的に、古典プロセッサは、例えば、各クラスタ内を平均化することにより、1つの状態sではなく、状態の組に基づいて各クラスタを収縮させる。これら又は他の実装形態では、収縮は、低エネルギー状態内で観測された統計及び各クラスタに制限されたエネルギー関数を更に考慮し得る。
【0069】
405において、古典プロセッサは、古典アルゴリズムを、縮小入力を有する問題に適用する。幾つかの実装形態では、パラレルテンパリングアルゴリズムが適用される。少なくとも1つの実装形態では、模擬アニーリングアルゴリズムが適用される。
【0070】
406において、古典プロセッサは、405において古典アルゴリズムを適用した後、縮小入力からのサンプルSrを得る。
【0071】
407において、古典プロセッサは、サンプルSrを拡張して、n個の集団変数の元の入力に対して変更された新しい状態の組を得る。状態sが404において入力の縮小に使用される場合、サンプルSrは、Srからの状態により示されるクラスタをフリップすることによりsに対して拡張される。幾つかの実装形態では、サンプルSrは、低エネルギー状態の組に基づいて拡張される。これら又は他の実装形態では、拡張は、低エネルギー状態の組内で観測された統計及びエネルギー関数を更に考慮し得る。
【0072】
408において、方法400は、例えば、再び呼び出されるまで終了する。
【0073】
図5は、クラスタ収縮を使用して計算問題を解く一例の反復方法500の流れ図である。方法500は、少なくとも1つの非量子、すなわち古典プロセッサを含む古典計算システムを介して実行される。代替的に、方法500は、古典プロセッサを使用するハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行することができる。方法500は、動作501~510を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0074】
方法500は、例えば、別のルーチンからの呼び出しに応答して、501において開始される。
【0075】
502において、方法400の動作402を参照して上述したように、古典プロセッサは、n個の集団変数を有する問題にアルゴリズムを適用する。
【0076】
503において、方法400の動作403を参照して上述したように、古典プロセッサは、n個の集団変数をk個のクラスタに区分けする。
【0077】
404において、方法400の動作404を参照して上述したように、古典プロセッサは、k個のクラスタのそれぞれを収縮させる。
【0078】
505において、方法400の動作405を参照して上述したように、古典プロセッサは、古典アルゴリズムを、縮小入力を有する問題に適用する。
【0079】
506において、古典プロセッサは、505において古典アルゴリズムを適用した後、縮小入力からのサンプルSrを得る。
【0080】
507において、方法400の動作407を参照して上述したように、古典プロセッサは、サンプルSrを拡張する。
【0081】
508において、古典プロセッサは、変更状態をn個の集団変数に統合する。
【0082】
509において、古典プロセッサは、終了条件が満たされたか否かをチェックする。終了条件が満たされた場合、制御は、510に渡り、他の場合、制御は、502に渡り、ここで、アルゴリズムが問題に再び適用される。終了条件は、集団変数の品質の尺度が満たされたか否かを判断することであり得る。
【0083】
510において、方法500は、例えば、再び呼び出されるまで終了する。
【0084】
代替的に、問題サイズは、古典ソルバのポートフォリオをn個の変数の問題に適用することにより縮小し、少なくとも1つのサンプル又は解を古典ソルバのポートフォリオ内の各古典ソルバから取得し、したがってk個の変数の縮小入力問題を取得することができ、ここで、k<nである。少なくとも1つの実装形態では、k≦nである。古典ソルバは、全て並行に異なる古典コンピュータで実行され得る。次に、縮小入力問題は、古典ソルバを使用して古典プロセッサで解くことができ、縮小入力に基づいてサンプルの組を取得する。代替的に、縮小入力は、縮小入力に基づいて量子プロセッサで解くことができる。サンプルの組は、次に、元の問題サイズに拡張することができる。
【0085】
図6は、古典ソルバのポートフォリオを使用するハイブリッド計算システムでの一例の動作方法600の流れ図である。方法600は、量子プロセッサ及び非量子、すなわち古典プロセッサを含むハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行される。
【0086】
方法600は、動作601~609を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0087】
方法600は、例えば、別のルーチンからの呼び出しに応答して、601において開始される。
【0088】
602において、古典プロセッサは、古典アルゴリズムのポートフォリオを、n個の集団変数を有する問題に適用する。問題は、601における入力の組の部分として受け取られ得る。少なくとも1つの実装形態では、古典アルゴリズムのポートフォリオは、パラレルテンパリング、模擬アニーリング及び分枝限定法を含む。アルゴリズムは、所定の時間にわたり、例えば605においてサンプルのクラスタを収縮させるために有用であり得る状態を生成するのに十分な時間にわたり適用され得る。
【0089】
603において、古典プロセッサは、各古典アルゴリズムから少なくとも1つのサンプルを取得する。
【0090】
604において、古典プロセッサは、サンプル統計に基づいてn個の集団変数をk個のクラスタに区分けする。
【0091】
605において、古典プロセッサは、k個のクラスタのそれぞれを収縮させ、したがって集団変数の数を低減し、602の問題への縮小入力を生成する。幾つかの実装形態では、古典プロセッサは、クラスタ内の全ての変数を、状態sに対するその値に基づいてクランプすることにより各クラスタを収縮させ、したがって602の問題への縮小入力を表すk個の変数を得る。状態sは、古典アルゴリズムのポートフォリオを実行した後、602において特定され得る。代替的に、古典プロセッサは、例えば、各クラスタ内を平均化することにより、1つの状態sではなく、状態の組に基づいて各クラスタを収縮させる。これら又は他の実装形態では、拡張は、低エネルギー状態内で観測された統計及び各クラスタに制限されたエネルギー関数を更に考慮し得る。少なくとも1つの実装形態では、kの値は、nに等しい値であり得る。
【0092】
606において、古典プロセッサは、縮小入力を有する問題を量子プロセッサに送る。幾つかの実装形態では、埋め込みアルゴリズム、例えばマイナー埋め込みは、縮小入力を有する問題に適用されて、量子プロセッサに送ることができる埋め込み問題を生成する。
【0093】
607において、量子プロセッサは、縮小入力からのサンプルSrを返す。
【0094】
608において、古典プロセッサは、サンプルSrを拡張して、n個の集団変数の元の入力に対して変更された新しい状態の組を得る。状態sが605において入力の縮小に使用される場合、サンプルSrは、Srからの状態により示されるクラスタをフリップすることによりsに対して拡張される。幾つかの実装形態では、サンプルSrは、低エネルギー状態の組に基づいて拡張される。これら又は他の実装形態では、拡張は、低エネルギー状態内で観測された統計(相互情報又は相関等)及びエネルギー関数を更に考慮し得る。
【0095】
609において、方法600は、例えば、再び呼び出されるまで終了する。
【0096】
図7は、古典ソルバのポートフォリオを使用するハイブリッド計算システムの動作の一例の反復方法700の流れ図である。方法700は、量子プロセッサ及び非量子、すなわち古典プロセッサを含むハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行される。
【0097】
方法700は、動作701~711を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0098】
方法700は、例えば、別のルーチンからの呼び出しに応答して、701において開始される。
【0099】
702において、方法600の動作602を参照して上述したように、古典プロセッサは、古典アルゴリズムのポートフォリオを、n個の集団変数を有する問題に適用する。
【0100】
703において、方法600の動作603を参照して上述したように、古典プロセッサは、各古典アルゴリズムから少なくとも1つのサンプルを取得する。
【0101】
704において、古典プロセッサは、サンプル統計に基づいてn個の集団変数をk個のクラスタに区分けする。
【0102】
705において、方法600の動作605を参照して上述したように、古典プロセッサは、k個のクラスタのそれぞれを収縮させる。
【0103】
706において、方法600の動作606を参照して上述したように、古典プロセッサは、縮小入力を有する問題を量子プロセッサに送る。
【0104】
707において、量子プロセッサは、縮小入力からのサンプルSrを返す。
【0105】
708において、方法600の動作608を参照して上述したように、古典プロセッサは、サンプルSrを拡張する。
【0106】
709において、古典プロセッサは、変更状態を動作702からの元の問題のn個の集団変数に統合する。
【0107】
710において、古典プロセッサは、終了条件が満たされたか否かをチェックする。終了条件が満たされた場合、制御は、711に渡り、他の場合、制御は、702に渡り、ここで、古典アルゴリズムのポートフォリオが問題に再び適用される。終了条件は、集団変数の品質の尺度が満たされたか否かを判断することであり得る。
【0108】
711において、方法700は、例えば、再び呼び出されるまで終了する。
【0109】
図8は、古典ソルバのポートフォリオを使用して計算問題を解く一例の方法800の流れ図である。方法800は、少なくとも1つの非量子、すなわち古典プロセッサを含む古典計算システムを介して実行される。代替的に、方法800は、古典プロセッサを使用するハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行することができる。方法800は、動作801~809を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0110】
方法800は、例えば、別のルーチンからの呼び出しに応答して、801において開始される。
【0111】
802において、古典計算システムは、古典アルゴリズムのポートフォリオを、n個の集団変数を有する問題に適用する。問題は、801における入力の組の部分として受け取られ得る。少なくとも1つの実装形態では、古典アルゴリズムのポートフォリオは、パラレルテンパリング、模擬アニーリング及び分枝限定法を含む。アルゴリズムは、所定の時間にわたり、例えば805においてサンプルのクラスタを収縮させるために有用であり得る状態を生成するのに十分な時間にわたり適用され得る。古典ソルバは、別個の古典プロセッサに並行して実行され得る。
【0112】
803において、古典プロセッサは、各古典アルゴリズムから少なくとも1つのサンプルを取得する。
【0113】
804において、古典プロセッサは、サンプル統計に基づいてn個の集団変数をk個のクラスタに区分けする。
【0114】
805において、古典プロセッサは、k個のクラスタのそれぞれを収縮させ、したがって集団変数の数を低減し、802の問題への縮小入力を生成する。幾つかの実装形態では、古典プロセッサは、クラスタ内の全ての変数を、状態sに対するその値に基づいてクランプすることにより各クラスタを収縮させ、したがって802の問題への縮小入力を表すk個の変数を得る。状態sは、古典アルゴリズムのポートフォリオを実行した後、602において特定され得る。代替的に、古典プロセッサは、例えば、各クラスタ内を平均化することにより、1つの状態sではなく、状態の組に基づいて各クラスタを収縮させる。これら又は他の実装形態では、収縮は、低エネルギー状態内で観測された統計及び各クラスタに制限されたエネルギー関数を更に考慮し得る。少なくとも1つの実装形態では、kの値は、nに等しい値であり得る。
【0115】
806において、古典プロセッサは、古典アルゴリズムを、縮小入力を有する問題に適用する。幾つかの実装形態では、パラレルテンパリングアルゴリズムが適用される。少なくとも1つの実装形態では、模擬アニーリングアルゴリズムが適用される。
【0116】
807において、古典プロセッサは、806において古典アルゴリズムを適用した後、縮小入力からのサンプルSrを得る。
【0117】
808において、古典プロセッサは、サンプルSrを拡張して、n個の集団変数の元の入力に対して変更された新しい状態の組を得る。状態sが805において入力の縮小に使用される場合、サンプルSrは、Srからの状態により示されるクラスタをフリップすることによりsに対して拡張される。幾つかの実装形態では、サンプルSrは、低エネルギー状態の組に基づいて拡張される。これら又は他の実装形態では、拡張は、低エネルギー状態の組内で観測された統計及びエネルギー関数を更に考慮し得る。
【0118】
809において、方法800は、例えば、再び呼び出されるまで終了する。
【0119】
図9は、古典ソルバのポートフォリオを使用して計算問題を解く動作の一例の反復方法900の流れ図である。方法900は、少なくとも1つの非量子、すなわち古典プロセッサを含む古典計算システムを介して実行される。代替的に、方法900は、古典プロセッサを使用するハイブリッド計算システム、例えばハイブリッド計算システム100を介して実行することができる。
【0120】
方法900は、動作901~911を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0121】
方法900は、例えば、別のルーチンからの呼び出しに応答して、901において開始される。
【0122】
902において、方法800の動作802を参照して上述したように、古典プロセッサは、古典アルゴリズムのポートフォリオを、n個の集団変数を有する問題に適用する。
【0123】
903において、方法800の動作803を参照して上述したように、古典プロセッサは、各古典アルゴリズムから少なくとも1つのサンプルを取得する。
【0124】
904において、古典プロセッサは、サンプル統計に基づいてn個の集団変数をk個のクラスタに区分けする。
【0125】
905において、方法800の動作805を参照して上述したように、古典プロセッサは、k個のクラスタのそれぞれを収縮させる。
【0126】
906において、方法800の動作806を参照して上述したように、古典プロセッサは、古典アルゴリズムを、縮小入力を有する問題に適用する。
【0127】
907において、古典プロセッサは、906において古典アルゴリズムを適用した後、縮小入力からのサンプルSrを得る。
【0128】
908において、方法800の動作808を参照して上述したように、古典プロセッサは、サンプルSrを拡張する。
【0129】
909において、古典プロセッサは、変更状態を動作902からの元の問題のn個の集団変数に統合する。
【0130】
910において、古典プロセッサは、終了条件が満たされたか否かをチェックする。終了条件が満たされた場合、制御は、911に渡り、他の場合、制御は、902に渡り、ここで、古典アルゴリズムが問題に再び適用される。終了条件は、集団変数の品質の尺度が満たされたか否かを判断することであり得る。
【0131】
911において、方法900は、例えば、再び呼び出されるまで終了する。
【0132】
特定のクラスの問題、例えば二次拘束二元最適化(QCBO)問題は、量子アニーラとして動作可能な量子プロセッサを用いて直接解くことができないことがある。QCBO問題は、大きいペナルティ項を追加することにより二次非拘束二元最適化(QUBO)問題に変換することができ、次に、量子プロセッサは、解をQUBOに提供するようにプログラムすることができる。ペナルティ項をQCBOに追加することは、制約を満たさないQUBOへの任意の潜在的な解が、ペナルティ項の1つ又は複数を生じさせ、したがって制約を満たすようにQUBOの任意の基底状態を向けることを保証するために必要である。
【0133】
しかしながら、QUBO問題へのペナルティ項の追加は、解くことを難しくさせることがある。特に、量子アニーラ等のアナログデバイスは、動作するために高い精度を必要とし、ペナルティ項の追加は、一般に、問題を解くために必要とされる制度の程度を上げる。したがって、ペナルティ項が追加されたQUBOを解くことは、アナログデバイス単独で実現可能でないことがある。したがって、追加の制約を遵守しながら、量子アニーラ等のアナログプロセッサを利用するハイブリッド方法は、QCBOを解くために望ましい。
【0134】
モンテカルロアルゴリズムは、変数フリップを提案し、エネルギーの変化に基づく確率で変数フリップを許容する。ハイブリッドモンテカルロアルゴリズムは、ハイブリッドモンテカルロアルゴリズムが、変数フリップ提案の組合せの結果としてのエネルギー変化に対応するエネルギーを有するQUBO問題を定式化する。QUBO内の各変数は、1つの変数フリップの許容又は拒絶に対応する。QUBOは、次に、量子プロセッサを介して解くことができ、生成される解は、許容される可能性が最も高い提案された変数フリップの組合せである。ハイブリッドモンテカルロアルゴリズムは、QCBO問題及び提案のサブセットを許容する効果がQUBOとしてモデリングすることができる他の問題に適用することができる。例えば、ハイブリッドモンテカルロアルゴリズムは、二次問題、混合整数問題及び整数二次プログラミングに適用することができる。
【0135】
ハイブリッドモンテカルロアルゴリズムは、まず、状態sを問題へのポテンシャル解として採用する。状態sは、ランダム状態であり得る。ハイブリッドモンテカルロアルゴリズムは、次に、複数の提案が集合的に2つの制約を遵守するように、状態sに提案される複数の変更(例えば、変数フリップ)を生成する。第1の制約は、2つの提案が同じ変数を変更しないことである。第2の制約は、3つ以上の提案が費用関数の項に影響しないことであり、ここで、費用関数(又はエネルギー/適合関数)は、全ての項の和として表現される。ハイブリッドモンテカルロアルゴリズムは、k個の提案を生成し得る。
【0136】
ハイブリッドモンテカルロアルゴリズムは、長さkの所与の二進列sbのQUBOのエネルギーが、sbで表されるk個の提案のサブセットを許容することによりsを変更した後に生じる状態sを有する元の問題のエネルギーに対応するように、k個の変数のQUBOを定式化する。
【0137】
QUBOは、次に、量子プロセッサ、例えば量子アニーラ又は任意の他のQUBOソルバにプログラムされて、解を提供することができる。解は、提案された変更のサブセットである。解に従って変数を変更することは、元の問題へのポテンシャル解として新しい状態sをもたらす。
【0138】
ハイブリッドモンテカルロアルゴリズムは、アルゴリズムの前の反復から変更された状態に基づいて、提案される新しい組の変更を生成し、QUBOを定式化し、量子プロセッサを介してQUBOを解くことを反復することができる。
【0139】
図10は、複数の制約ベースの更新を用いるハイブリッド計算システムの一例の動作方法1000の流れ図である。方法1000は、量子プロセッサ及び古典プロセッサを含むハイブリッド計算システム、例えば
図1のハイブリッド計算システム100で実行され、ハイブリッド計算システム100を参照して説明される。
【0140】
方法1000は、動作1001~1007を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0141】
方法1000は、例えば、別のルーチンからの呼び出しに応答して、1001において開始される。
【0142】
1002において、ハイブリッド計算システム100は、状態sを問題への解と見なす。状態sは、ランダム状態又は入力の組の一部としてのものであり得る。
【0143】
1003において、ハイブリッド計算システム100は、2つの制約を満たす、状態sに関する変更提案を生成することが可能であるか否かを判断する。制約は、2つの提案が同じ変数を変更しないこと及び3つ以上の提案が費用関数の項に影響しないことである。第1の提案は、常に制約を満たすが、現在の提案と前に生成された提案との和集合は、両方の制約を満たさないことがある。そのような提案を生成することが可能である場合、制御は、1004に渡り、他の場合、制御は、1005に渡る。
【0144】
1004において、ハイブリッド計算システム100は、変更提案を生成する。提案は、後に使用するためにメモリシステムに記憶され得る。制御は、1003に渡り、ハイブリッド計算システム100は、制約を遵守する別の提案を生成することが可能であるか否かを判断する。
【0145】
1005において、ハイブリッド計算システム100は、k個の変数のQUBOを定式化し、ここで、kは、長さkの所与の二進列sbのQUBOのエネルギーが、sbで表されるk個の提案のサブセットを許容することによりsを変更した後に生じる状態sを有する元の問題のエネルギーに対応するような変更提案数である。
【0146】
1006において、ハイブリッド計算システム100は、QUBOを量子プロセッサ124によって解かせる。量子プロセッサ124からの解は、提案された変更のサブセットである。解に従って変数を変更することは、元の問題へのポテンシャル解として新しい状態sをもたらす。
【0147】
1007において、方法1000は、例えば、再び呼び出されるまで終了する。
【0148】
図11は、複数の制約ベースの更新を用いるハイブリッド計算システムの動作の一例の反復方法1100の流れ図である。
【0149】
方法1100は、量子プロセッサ及び古典プロセッサを含むハイブリッド計算システム、例えば
図1のハイブリッド計算システム100で実行され、ハイブリッド計算システム100を参照して説明される。
【0150】
方法1100は、動作1101~1109を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0151】
方法1100は、例えば、別のルーチンからの呼び出しに応答して、1101において開始される。
【0152】
1102において、方法1000の動作1002を参照して上述したように、ハイブリッド計算システム100は、状態sを問題への解と見なす。
【0153】
1103において、方法1100の動作1003を参照して上述したように、ハイブリッド計算システム100は、2つの制約を満たす、状態snに関する変更提案を生成することが可能であるか否かを判断する。
【0154】
1104において、方法1000の動作1004を参照して上述したように、ハイブリッド計算システム100は、変更提案を生成する。
【0155】
1105において、方法1000の動作1005を参照して上述したように、ハイブリッド計算システム100は、QUBOを定式化する。
【0156】
1106において、方法1000の動作1006を参照して上述したように、ハイブリッド計算システム100は、QUBOを量子プロセッサ124によって解かせる。
【0157】
1107において、ハイブリッド計算システム100は、状態snを状態sn+1に変更し、ここで、sn+1は、動作1106においてQUBOの解により表されるk個のサブセットを許容することにより状態snを変更した後に生成される状態である。
【0158】
1108において、ハイブリッド計算システム100は、終了条件が満たされたか否かを判断する。少なくとも1つの実装形態では、終了条件は、状態sn+1の品質尺度が満たされることである。別の実装形態では、終了条件は、方法1100の反復数の完了である。
【0159】
1109において、方法1100は、例えば、再び呼び出されるまで終了する。
【0160】
量子プロセッサ及び古典プロセッサを含むハイブリッド計算システム、例えばハイブリッド計算システム100で実行されるアルゴリズムは、問題を量子プロセッサのハードウェアに適合させる埋め込みアルゴリズムから恩恵を受け得る。
【0161】
問題を量子プロセッサのトポロジに埋め込む一例のアルゴリズムは、以下の埋め込み基準に基づく。ソースグラフS及び例えば量子プロセッサのトポロジを表すターゲットグラフTを所与として、εの埋め込みは、以下であるようなSのノードからTのノードの組へのマッピングとして定義される。
1.各ν∈V(S)について、誘導されるサブグラフT[ε(ν)]は、非空であり、連結され、
2.全てのu、ν∈V(S)について、u≠νである場合のみ、ε(u)∩ε(ν)=φである。組ε(ν)は、連鎖と呼ばれる。
【0162】
第2の基準は、以下に記載するようにテアアップ及び置換演算を用いて緩和することができる。
【0163】
ソースノードu∈Sについて、
1.ε(u):={}に設定。
2.各ノードq∈Tについて、ペナルティ関数W(u,q):=α
|{(v∈S:q∈ε(v))}|を定義する-現在、qを占有しているソースノード数における指数関数。
3.uの各S近傍νについて、ダイクストラアルゴリズムのノード加重変形を実行して、W(u,q)をqの重みとしてノード距離D(ν,q)及び親P(ν,q)を計算する。
4.各ノードq∈Tについて、ルート費用推定R(q):=Σ
ν~uD(ν,q)を定義し、式中、ν~uは、νがuのS近傍であることを意味する。
5.R(q)を最小化するノードq
0を選択し、ε(u):={q
o}を更新する。
6.各S近傍νについて、q0から親を通してε(ν)までのパス:
【数4】
を構築し、パス(pを省略)をε(u)に追加する。
【0164】
上記のアルゴリズムは、グラフSで定義される問題から、グラフTで定義される埋め込み問題への重なり埋め込みと呼ばれる埋め込みを返す。上記のアルゴリズムは、ヒューリスティック的に改善される外部供給の重なり埋め込みと併用することもできる。
【0165】
イジング問題を所与として、変数[σ
1,...,σ
n]にわたり、
【数5】
であり、全てのiについてJ
i,i=0の場合、縮小は、これらの変数の相対割り当てであり、イジング問題の制約部分空間を表す。i≠jでの縮小(σ
x≡±σ
y)は、n-1個の変数にわたり縮小イジング問題を生成し、これは、Eの記号簡略化を介して計算することができる。イジング問題がQUBOに変換可能であることを当業者は理解するであろう。
【0166】
本開示のシステム及び方法は、ペナルティ関数を最小化する埋め込み可能な縮小を見つけるために、フィードバックプロセスにおいて計算、埋め込み及び縮小を用いるアルゴリズムを記載する。ペナルティ関数は、ユーザにより又は別の方法若しくはアルゴリズムにより供給し得る。
【0167】
図12は、縮小及びそれらの埋め込みを計算するハイブリッド計算システムにおける一例の動作方法1200の流れ図である。方法1200は、量子プロセッサ及び古典プロセッサを含むハイブリッド計算システム、例えば
図1のハイブリッド計算システム100で実行され、ハイブリッド計算システム100を参照して説明される。方法1200は、問題の入力サイズを縮小し、それを量子プロセッサに埋め込むために、方法200(
図2)、300(
図3)、400(
図4)、500(
図5)、600(
図6)、700(
図7)、800(
図8)及び900(
図9)の一環として利用し得る。
【0168】
方法1200は、動作1201~1211を含むが、動作の数は、一例であり、幾つかの実装形態では、特定の動作を省略し得、更なる動作を追加し得、及び/又は動作の順序が変更可能であることを当業者は理解するであろう。
【0169】
方法1200は、例えば、別のルーチンからの呼び出しに応答して、1201において開始される。
【0170】
1202において、ハイブリッド計算システム100は、縮小ペナルティ生成関数Xを受け取る。縮小ペナルティ生成関数Xは、Sノードの各順序付き対(u,ν)にペナルティX(u,ν)を割り当てる。縮小ペナルティ生成関数Xは、方法1200への入力の組の一部として受け取られ得る。
【0171】
1203において、ハイブリッド計算システム100は、1202の縮小ペナルティ生成関数Xに基づいて新しいペナルティ関数
【数6】
を決定する。
【0172】
1204において、ハイブリッド計算システム100は、1203のペナルティ関数W’に従ってSからTへの重なり埋め込みεを特定する。ハイブリッド計算システム100は、ヒューリスティック埋め込みを使用して、重なり埋め込みを生成し得る。
【0173】
1205において、ハイブリッド計算システム100は、1204において特定された重なり埋め込みεが重複連鎖を含むか否かを判断する。εが重複連鎖を含む場合、制御は、1206に渡り、他の場合、制御は、1211に渡り、方法1200は、終了する。
【0174】
1206において、ハイブリッド計算システム100は、各Tノードqについてsノードの組Y(q)={ν:q∈ε(ν)}を計算する。
【0175】
1207において、ハイブリッド計算システム100は、グラフGからエッジのフォレストMを選択し、ここで、Gは、任意のq及びエッジ重み1-X(u,ν)で、{u,ν}⊂Y(q)の場合、エッジ(u,ν)を有するグラフとして定義される。ハイブリッド計算システム100は、幾つかの技法に従ってフォレストMを選択し得る。一実装形態では、Mは、エッジ重みに従った分布でランダムに選択される1つのエッジを含むシングルトンであり得る。代替的に、Mは、Gの最大重みマッチングであり得る。別の実装形態では、Mは、エッジをランダムに追加することにより構築されたフォレストであり得、確率は、各重みに従う。更に別の実装形態では、エッジ重みは、ε(u)∪ε(ν)のサイズ、誘導されるグラフT[ε(u)∪ε(ν)]の直径又はマージされた連鎖の性能を予測するより複雑な尺度により更に拡張される。
【0176】
12008において、ハイブリッド計算システム100は、縮小イジング問題を特定する。各(a,b)∈Mについて、ハイブリッド計算システム100は、(σa≡±σb)を割り当て、bを簡略化する。ハイブリッド計算システム100は、複数の技法に従って符号を選択し得る。幾つかの実装形態では、過去のサンプルのコーパスが利用可能である場合、1つのサンプルが採用され、各関係の符号は、サンプルに基づいて選択される。代替的に、過去のサンプルのコーパスが利用可能である場合、各関係の符号は、各関係のサンプルエネルギーに従って分布する、そのコーパスに見られる関係から選択される:(σa≡σb)vs(σa≡-σb)。更に別の実装形態では、例えば、方法1200の連続反復で問題が既に縮小されている場合、ハイブリッド計算システム100は、補助ソルバからサンプルのコーパスを収集し、上記の技法の1つに従って各関係の符号を特定する。少なくとも1つの実装形態では、エッジ及び符号の選択は、縮小イジング問題のハミルトニアンにおける最大大きさhi及びJi,jを最小化するエッジ及び符号を選択することにより並行して行われる。これら又は他の実装形態では、収縮は、低エネルギー状態内で観測される統計及び各クラスタに制限されたエネルギー関数を更に考慮し得る。
【0177】
12009において、ハイブリッド計算システム100は、ペナルティ関数を縮小する。ハイブリッド計算システム100は、幾つかの技法に従ってXを縮小し得る。一実装形態では、Mの各(a,b)について、ハイブリッド計算システム100は、X(a,x):=X(a,x)+X(b,x)及びX(x,b):=X(x,a)+X(x,b)を設定し、間隔(0,1)に正規化する。代替的に、Xがサンプルのコーパスから計算される場合、ハイブリッド計算システム100は、1208の符号選択に従ってコーパスをフィルタリングし、縮小コーパスでXを再計算する。更に別の実装形態では、ハイブリッド計算システム100は、補助ソルバを介して1208の縮小イジング問題からサンプルを計算し、得られたサンプルからXを再計算する。
【0178】
1210において、ハイブリッド計算システム100は、埋め込みεを縮小する。ハイブリッド計算システム100は、幾つかの異なる技法に従って埋め込みεを縮小し得る。一実装形態では、ハイブリッド計算システム100は、Mの各(a,b)について、ε(a):=ε(a)∪ε(b)に設定し、1208の縮小イジング問題に向けてヒューリスティックソルバを介して埋め込みεを改良する。代替的に、ハイブリッド計算システム100は、ヒューリスティックソルバを介して新しい埋め込みεを決定し、幾つかの場合、新しい埋め込みは、重なり埋め込みであり得る。
【0179】
12011において、方法1200は、例えば、再び呼び出されるまで終了する。
【0180】
実施形態例の列記
以下に列記される実施形態は、本発明の非限定的な実施形態例の特徴及び特徴の組合せの例を提供する。
【0181】
実施形態例1.量子プロセッサ及び古典プロセッサを含むハイブリッド計算システムの動作の方法であって、
古典プロセッサを介して、n個の集団変数を有する入力を有する問題にアルゴリズムを適用することと、
古典プロセッサを介して、n個の集団変数を有する入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、
量子プロセッサを介して、縮小入力からのサンプルSrを得ることと、
古典プロセッサを介して、サンプルSrを拡張して、問題への変更状態の組を得ることと
を含む方法。
【0182】
実施形態例2.古典プロセッサを介して、n個の集団変数を有する入力を有する問題にアルゴリズムを適用することは、古典プロセッサを介して、n個の集団変数を有する入力を有する問題にパラレルテンパリングアルゴリズムを適用することを含む、実施形態例1に記載の方法。
【0183】
実施形態例3.n個の集団変数を有する入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することは、n個の集団変数をk個のクラスタに区分けし、且つk個のクラスタのそれぞれを収縮させて、k個の集団変数を有する縮小入力を生成することを含む、実施形態例1又は2に記載の方法。
【0184】
実施形態例4.k個のクラスタのそれぞれを収縮させて、k個の集団変数を有する縮小入力を生成することは、低エネルギー状態sに関してk個のクラスタのそれぞれを収縮させて、k個の集団変数を有する縮小入力を生成することを含み、及びサンプルSrを拡張して、問題への変更状態の組を得ることは、低エネルギー状態sに関してサンプルSrを拡張して、問題への変更状態の組を得ることを含む、実施形態例3に記載の方法。
【0185】
実施形態例5.低エネルギー状態sに関してk個のクラスタのそれぞれを収縮させることは、各クラスタ内の全ての集団変数を、状態sにおけるその値に基づいて互いに対してクランプすることを含む、実施形態例4に記載の方法。
【0186】
実施形態例6.低エネルギー状態sに関してk個のクラスタのそれぞれを収縮させることは、クラスタリングに基づいて新しい状態sを作成することを含む、実施形態例5に記載の方法。
【0187】
実施形態例7.n個の集団変数をk個のクラスタに区分けすることは、状態の低エネルギーサブセットを使用してn個の集団変数をk個のクラスタに区分けすることを含む、実施形態例3に記載の方法。
【0188】
実施形態例8.k個のクラスタのそれぞれを収縮させることは、各クラスタ内の状態の低エネルギーサブセットに関して全ての集団変数の値を平均化することを含む、実施形態例7に記載の方法。
【0189】
実施形態例9.状態の低エネルギーサブセットを使用してn個の集団変数をk個のクラスタに区分けすることは、算術平均アルゴリズムを用いる非加重対グループ方法を介してn個の集団変数をk個のクラスタに区分けすることを含む、実施形態例7又は8に記載の方法。
【0190】
実施形態例10.算術平均アルゴリズムを用いる非加重対グループ方法を介してn個の集団変数をk個のクラスタに区分けすることは、距離尺度として対エントロピーを使用して、算術平均アルゴリズムを用いる非加重対グループ方法を介してn個の集団変数をk個のクラスタに区分けすることを含む、実施形態例9に記載の方法。
【0191】
実施形態例11.クラスタリングに基づいて新しい状態sを作成することは、ヒューリスティックソルバを使用して、各クラスタについて新しい状態sを作成することを含む、実施形態例6に記載の方法。
【0192】
実施形態例12.量子プロセッサを介して、縮小入力からのサンプルSrを得ることは、量子プロセッサを介して、縮小入力からのサンプルSrを得る前に、古典プロセッサを介して、縮小入力を有する問題に埋め込みアルゴリズムを適用することを含む、実施形態例1~11の何れか一項に記載の方法。
【0193】
実施形態例13.終了条件が満たされるまで、
古典プロセッサを介して、問題にアルゴリズムを適用することと、
古典プロセッサを介して、n個の集団変数を有する入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、
量子プロセッサを介して、縮小入力からのサンプルSrを得ることと、
古典プロセッサを介して、サンプルSrを拡張して、問題への変更状態の組を得ることと、
変更状態を問題に統合することと
を反復的に繰り返すことを更に含む、実施形態例1~12の何れか一項に記載の方法。
【0194】
実施形態例14.終了条件が満たされたか否かを判断することを更に含む、実施形態例13に記載の方法。
【0195】
実施形態例15.終了条件が満たされたか否かを判断することは、集団変数の品質の尺度が満たされているか否かを判断することを含む、実施形態例14に記載の方法。
【0196】
実施形態例16.量子プロセッサ及び古典プロセッサを含むハイブリッド計算システムであって、古典プロセッサは、
n個の集団変数を有する入力を有する問題にアルゴリズムを適用することと、
n個の集団変数を有する入力を、k個の集団変数を有する縮小入力に変換することであって、k≦nである、変換することと、
量子プロセッサから、縮小入力からのサンプルSrを得ることと、
サンプルSrを拡張して、問題への変更状態の組を得ることと
を行うように動作可能である、ハイブリッド計算システム。
【0197】
実施形態例17.アルゴリズムは、パラレルテンパリングアルゴリズムである、実施形態例16に記載のシステム。
【0198】
実施形態例18.古典プロセッサは、n個の集団変数をk個のクラスタに区分けし、且つk個のクラスタのそれぞれを収縮させて、k個の変数を有する縮小入力を生成するように動作可能である、実施形態例16又は17に記載のシステム。
【0199】
実施形態例19.k個のクラスタのそれぞれは、低エネルギー状態sに関して収縮され、及びサンプルSrは、低エネルギー状態sに関して拡張される、実施形態例18に記載のシステム。
【0200】
実施形態例20.各クラスタ内の全ての集団変数は、状態sにおけるその値に基づいて互いに対してクランプされる、実施形態例19に記載のシステム。
【0201】
実施形態例21.n個の集団変数は、状態の低エネルギーサブセットを使用してk個のクラスタに区分けされる、実施形態例18に記載のシステム。
【0202】
実施形態例22.全ての集団変数の値は、各クラスタ内の状態の低エネルギーサブセットに関して平均化される、実施形態例21に記載のシステム。
【0203】
実施形態例23.n個の集団変数は、算術平均アルゴリズムを用いる非加重対グループ方法を介してk個のクラスタに区分けされる、実施形態例21又は22に記載のシステム。
【0204】
実施形態例24.算術平均アルゴリズムを用いる非加重対グループ方法は、距離尺度として対エントロピーを使用する、実施形態例23に記載のシステム。
【0205】
実施形態例25.新しい状態sは、クラスタリングに基づいて作成される、実施形態例20に記載のシステム。
【0206】
実施形態例26.ヒューリスティックソルバは、各クラスタについて新しい状態sを作成するために使用される、実施形態例25に記載のシステム。
【0207】
実施形態例27.古典プロセッサは、量子プロセッサから、縮小入力からのサンプルSrを得る前に、埋め込みアルゴリズムを介して、縮小入力を有する問題を埋め込むように動作可能である、実施形態例16~26の何れか一項に記載のシステム。
【0208】
実施形態例28.量子プロセッサ及び古典プロセッサを含むハイブリッド計算システムの動作の方法であって、
古典プロセッサを介して、問題の状態sに関して複数の変数変更提案を生成することと、
古典プロセッサを介して、複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
量子プロセッサを介して、二次非拘束二元最適化問題を解くことと
を含む方法。
【0209】
実施形態例29.問題についての複数の変数変更提案を生成することは、二次拘束二元最適化問題及び整数二次プログラミング問題の一方からなる問題についての複数の変数変更提案を生成することを含む、実施形態例28に記載の方法。
【0210】
実施形態例30.状態sに関して複数の変数変更提案を生成することは、ランダム状態sに関して問題についての複数の変数変更提案を生成することを含む、実施形態例28又は29に記載の方法。
【0211】
実施形態例31.古典プロセッサを介して、状態sに関して複数の変数変更提案を生成することは、2つの提案が同じ変数を変更せず、及び3つ以上の提案が二次非拘束二元最適化問題の費用関数の項に影響しないように複数の変数変更提案を生成することを含む、実施形態例28~30の何れか一項に記載の方法。
【0212】
実施形態例32.二次非拘束二元最適化問題を解くことにより、指定された複数の変数変更提案のサブセットを許容することによって状態sを変更し、且つ終了条件が満たされるまで、
古典プロセッサを介して、状態sn-1に関して複数の変数変更提案を生成することと、
古典プロセッサを介して、変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
量子プロセッサを介して、二次非拘束二元最適化問題を解くことと、
二次非拘束二元最適化問題を解くことにより、指定された提案のサブセットを許容することによって状態sn-1を状態snに変更することと
を反復的に繰り返すことを更に含む、実施形態例28~31の何れか一項に記載の方法。
【0213】
実施形態例33.終了条件が満たされたか否かを判断することを更に含む、実施形態例32に記載の方法。
【0214】
実施形態例34.終了条件が満たされたか否かを判断することは、反復数及び状態snが品質の尺度を満たすことの群からの少なくとも1つの条件が満たされたか否かを判断することを含む、実施形態例33に記載の方法。
【0215】
実施形態例35.古典プロセッサ及び量子プロセッサを含むハイブリッド計算システムであって、古典プロセッサは、
問題の状態sに関して複数の変数変更提案を生成することと、
複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
量子プロセッサに二次非拘束二元最適化問題を解かせることと
を行うように動作可能である、ハイブリッド計算システム。
【0216】
実施形態例36.問題は、二次拘束二元最適化問題及び整数二次プログラミング問題の少なくとも一方である、実施形態例35に記載のシステム。
【0217】
実施形態例37.状態sは、ランダム状態sである、実施形態例35又は36に記載のシステム。
【0218】
実施形態例38.前記古典プロセッサは、2つの提案が同じ変数を変更せず、及び3つ以上の提案が二次非拘束二元最適化問題の費用関数の項に影響しないように複数の変数変更提案を生成するように動作可能である、実施形態例35~37の何れか一項に記載のシステム。
【0219】
実施形態例39.古典プロセッサは、二次非拘束二元最適化問題を解くことにより、指定された複数の変数変更提案のサブセットを許容することによって状態sを変更し、且つ終了条件が満たされるまで、
状態sn-1に関して複数の変数変更提案を生成することと、
変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
量子プロセッサに二次非拘束二元最適化問題を解かせることと、
二次非拘束二元最適化問題を解くことにより、指定された提案のサブセットを許容することによって状態sn-1を状態snに変更することと
を反復的に繰り返すように更に動作可能である、実施形態例35~38の何れか一項に記載のシステム。
【0220】
実施形態例40.終了条件が満たされたか否かを判断するように動作可能な古典プロセッサを更に含む、実施形態例39に記載のシステム。
【0221】
実施形態例41.古典プロセッサは、経過した反復数及び状態snが品質の尺度を満たすことを含む終了条件の群の1つが満たされたか否かを判断するように動作可能である、実施形態例40に記載のシステム。
【0222】
上記の方法、プロセス又は技法は、1つ又は複数の非一時的プロセッサ可読媒体に記憶された一連のプロセッサ可読命令により実施することができる。上記の方法、プロセス又は技法、方法の幾つかの例は、部分的に、断熱量子コンピュータ若しくは量子アニーラ等の専用デバイス又は断熱量子コンピュータ若しくは量子アニーラの動作をプログラム若しくは他の方法で制御するシステム、例えば少なくとも1つのデジタルプロセッサを含むコンピュータにより実行される。上記の方法、プロセス又は技法が種々の動作を含み得、代替の例では、特定の動作を省き得、及び/又は追加の動作を追加し得ることを当業者は理解するであろう。動作の示された順序が単に例を目的としたものであり、代替の例では変更され得ることを当業者は理解するであろう。上記の方法、プロセス又は技法の動作又は演算の幾つかは、反復的に実行される。上記の方法、プロセス又は技法の幾つかの動作は、各反復中、複数の反復後又は全ての反復後に実行することができる。
【0223】
要約書に記載されるものを含め、示された実装形態の上記の説明は、網羅的であること又は開示された厳密な形態に実装形態を限定することを意図しない。特定の実装形態及び例が例示目的で本明細書に記載されているが、当業者に認識されるように、他の趣旨及び範囲から逸脱せずに種々の均等な変更形態がなされ得る。種々の実装形態の本明細書に提供される教示は、必ずしも、概して上述した量子計算の方法例ではなく、量子計算の他の方法に適用することも可能である。
【0224】
上述した種々の実装形態を組み合わせて、更なる実装形態を提供することができる。本明細書において参照され、及び/又は出願データシートに列記される本願の譲受人に譲渡された米国特許出願公開、米国特許出願、外国特許及び外国特許出願の全ては、米国特許第7,533,068号を含むが、これに限定されず、全体的に参照により本明細書に援用される。
【0225】
上記の詳細な説明に鑑みて、実装形態に対するこれら及び他の変更形態がなされ得る。一般に、以下の特許請求の範囲において、使用される用語は、本明細書及び特許請求の範囲において開示される特定の実装形態に請求項を限定するものとして解釈されるべきではなく、そのような特許請求の範囲が権利を有する全範囲の均等物と共に可能な全ての実装形態を包含するものと解釈されるべきである。したがって、特許請求の範囲は、本開示により限定されない。
【手続補正書】
【提出日】2024-08-27
【手続補正1】
【補正対象書類名】特許請求の範囲
【補正対象項目名】全文
【補正方法】変更
【補正の内容】
【特許請求の範囲】
【請求項1】
量子プロセッサ及び古典プロセッサを含むハイブリッド計算システムの動作の方法であって、
前記古典プロセッサを介して、問題の状態sに関して複数の変数変更提案を生成することであって、2つの提案が同じ変数を変更せず、及び3つ以上の提案が二次非拘束二元最適化問題の費用関数の項に影響しない、ことと、
前記古典プロセッサを介して、前記複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサを介して、前記二次非拘束二元最適化問題を解くことと
を含む方法。
【請求項2】
問題についての複数の変数変更提案を生成することは、二次拘束二元最適化問題及び整数二次プログラミング問題の一方からなる問題についての複数の変数変更提案を生成することを含む、請求項1に記載の方法。
【請求項3】
状態sに関して複数の変数変更提案を生成することは、ランダム状態sに関して問題についての複数の変数変更提案を生成することを含む、請求項1又は2に記載の方法。
【請求項4】
前記二次非拘束二元最適化問題を解くことにより、指定された前記複数の変数変更提案の前記サブセットを許容することによって前記状態sを変更し、且つ終了条件が満たされるまで、
前記古典プロセッサを介して、状態sn-1に関して複数の変数変更提案を生成することと、
前記古典プロセッサを介して、前記変数変更提案のサブセットを許容する前記エネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサを介して、前記二次非拘束二元最適化問題を解くことと、
前記二次非拘束二元最適化問題を解くことにより、指定された前記提案の前記サブセットを許容することによって前記状態sn-1を状態snに変更することと
を反復的に繰り返すことを更に含む、請求項1に記載の方法。
【請求項5】
終了条件が満たされたか否かを判断することを更に含む、請求項4に記載の方法。
【請求項6】
終了条件が満たされたか否かを判断することは、反復数及び前記状態snが品質の尺度を満たすことの群からの少なくとも1つの条件が満たされたか否かを判断することを含む、請求項5に記載の方法。
【請求項7】
古典プロセッサ及び量子プロセッサを含むハイブリッド計算システムであって、前記古典プロセッサは、
問題の状態sに関して複数の変数変更提案を生成することであって、2つの提案が同じ変数を変更せず、及び3つ以上の提案が二次非拘束二元最適化問題の費用関数の項に影響しない、ことと、
前記複数の変数変更提案のサブセットを許容するエネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサに前記二次非拘束二元最適化問題を解かせることと、
を行うように動作可能である、ハイブリッド計算システム。
【請求項8】
前記問題は、二次拘束二元最適化問題及び整数二次プログラミング問題の少なくとも一方である、請求項7に記載のシステム。
【請求項9】
前記状態sは、ランダム状態sである、請求項7又は8に記載のシステム。
【請求項10】
前記古典プロセッサは、前記二次非拘束二元最適化問題を解くことにより、指定された前記複数の変数変更提案の前記サブセットを許容することによって前記状態sを変更し、且つ終了条件が満たされるまで、
状態sn-1に関して複数の変数変更提案を生成することと、
前記変数変更提案のサブセットを許容する前記エネルギー変化に対応する二次非拘束二元最適化問題を定式化することと、
前記量子プロセッサに前記二次非拘束二元最適化問題を解かせることと、
前記二次非拘束二元最適化問題を解くことにより、指定された前記提案の前記サブセトを許容することによって前記状態sn-1を状態snに変更することと
を反復的に繰り返すように更に動作可能である、請求項7に記載のシステム。
【請求項11】
前記終了条件が満たされたか否かを判断するように動作可能な前記古典プロセッサを更に含む、請求項10に記載のシステム。
【請求項12】
前記古典プロセッサは、経過した反復数及び前記状態snが品質の尺度を満たすことを含む終了条件の群の1つが満たされたか否かを判断するように動作可能である、請求項11に記載のシステム。
【外国語明細書】