JP2022142914A - 求解装置およびプログラム - Google Patents

求解装置およびプログラム Download PDF

Info

Publication number
JP2022142914A
JP2022142914A JP2021043184A JP2021043184A JP2022142914A JP 2022142914 A JP2022142914 A JP 2022142914A JP 2021043184 A JP2021043184 A JP 2021043184A JP 2021043184 A JP2021043184 A JP 2021043184A JP 2022142914 A JP2022142914 A JP 2022142914A
Authority
JP
Japan
Prior art keywords
function
lagrangian
solution
variables
decision variables
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2021043184A
Other languages
English (en)
Other versions
JP7455773B2 (ja
Inventor
賢 鈴木
Masaru Suzuki
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Toshiba Corp
Toshiba Digital Solutions Corp
Original Assignee
Toshiba Corp
Toshiba Digital Solutions Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Toshiba Corp, Toshiba Digital Solutions Corp filed Critical Toshiba Corp
Priority to JP2021043184A priority Critical patent/JP7455773B2/ja
Priority to CA3212411A priority patent/CA3212411A1/en
Priority to PCT/JP2022/012072 priority patent/WO2022196739A1/ja
Publication of JP2022142914A publication Critical patent/JP2022142914A/ja
Priority to US18/466,878 priority patent/US20230418895A1/en
Application granted granted Critical
Publication of JP7455773B2 publication Critical patent/JP7455773B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/11Complex mathematical operations for solving equations, e.g. nonlinear equations, general mathematical optimization problems
    • G06F17/12Simultaneous equations, e.g. systems of linear equations
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/11Complex mathematical operations for solving equations, e.g. nonlinear equations, general mathematical optimization problems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N99/00Subject matter not provided for in other groups of this subclass

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Computational Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Algebra (AREA)
  • Operations Research (AREA)
  • Computing Systems (AREA)
  • Complex Calculations (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

【課題】良い解を効率良く算出する。【解決手段】求解装置は、非凸二次関数である目的関数を最小化する問題の解を、J個の連立一次方程式を満たし且つK個の連立一次不等式を満たす条件の下で算出する。求解装置は、取得部と、更新部と、出力部とを備える。更新部は、拡張ラグランジュ関数に基づき生成されるI個の決定変数を含む第1関数を最小化するI個の決定変数の解の候補値を取得する第1処理、拡張ラグランジュ関数に基づき生成されるK個の従属変数を含む第2関数を最小化するK個の従属変数の解の候補値を取得する第2処理、および、拡張ラグランジュ関数に含まれる係数を更新する係数処理、を予め定められた順序で繰り返す。拡張ラグランジュ関数は、目的関数を含む目的関数項と、J個の連立一次方程式に対応するJ個の第1ラグランジュ項と、K個の連立一次不等式に対応するK個の第2ラグランジュ項と、ペナルティ項と、を含む。【選択図】図2

Description

本発明の実施形態は、求解装置およびプログラムに関する。
最適化問題の一つとして、線形制約・0-1整数非凸二次計画問題が知られている。線形制約・0-1整数非凸二次計画問題は、それぞれが0または1となる複数の決定変数を含む非凸二次関数を最小化する解を、複数の連立一次方程式および複数の連立一次不等式の制約条件の下で、算出する問題である。線形制約・0-1整数非凸二次計画問題は、スケジューリングの最適化等に応用される。
線形制約・0-1整数非凸二次計画問題の求解方法として、例えば、分枝限定法または近似解法が知られている。分枝限定法は、決定変数の1つ1つに対して場合分けを行って、目的関数値の上界および下界を算出する。そして、分枝限定法は、大域的最適解を取りえる範囲を絞り込んでいきながら、大域的最適解を算出する。
近似解法は、例えば、等式制約および不等式制約のそれぞれを、制約に違反する量の二乗に比例する障壁関数により表す。そして、近似解法は、有効と推定される制約のみを利用することにより、無制約・0-1整数非凸二次計画問題に変換し、この問題をイジングマシンで解く。
しかし、分枝限定法は、決定変数の1つ1つに対して場合分けを行うため、決定変数の数に対して計算量が指数的に増大してしまっていた。また、近似解法は、制約の周辺での目的関数の傾きが大きい場合、障壁関数の比例係数であるペナルティパラメータを、目的関数の傾きより大きくしなければならない。
このような場合、近似解法は、イジングマシンへの入力行列の係数の大きさが、目的関数に由来する係数よりもペナルティパラメータに由来する係数の方が大きくなってしまう。このため、近似解法は、実行可能解を算出するためにイジングマシンの計算能力の多くを費やすこととなり、効率が悪かった。また、近似解法は、悪い目的関数値をもつ解に到達する場合もあるので、良い目的関数値をもつ解に到達するために、ペナルティパラメータに対してハイパーパラメータチューニングを行わなければならなく、処理が複雑となってしまっていた。
特開2020-144529号公報
Lawler, E. L., & Wood, D. E., "Branch-and-bound methods", A survey. Operations research, 14(4),1996, 699-719.
本発明が解決しようとする課題は、良い解を効率良く算出することができる求解装置およびプログラムを提供することにある。
実施形態に係る求解装置は、それぞれが0または1となるI個(Iは2以上の整数)の決定変数を含む非凸二次関数である目的関数を最小化する問題の解を、それぞれが前記I個の決定変数のうちの少なくとも1つを変数として含むJ個(Jは0以上の整数)の連立一次方程式を満たし且つそれぞれが前記I個の決定変数のうちの少なくとも1つを変数として含むK個(Kは1以上の整数)の連立一次不等式を満たす条件の下で、算出する。前記求解装置は、取得部と、更新部と、出力部とを備える。前記取得部は、前記目的関数、前記J個の連立一次方程式および前記K個の連立一次不等式を取得する。前記更新部は、拡張ラグランジュ関数に基づき生成される前記I個の決定変数を含む第1関数を最小化する前記I個の決定変数の解の候補値を取得する第1処理、前記拡張ラグランジュ関数に基づき生成されるK個の従属変数を含む第2関数を最小化する前記K個の従属変数の解の候補値を取得する第2処理、および、前記拡張ラグランジュ関数に含まれる係数を更新する係数処理、を予め定められた順序で繰り返す。前記出力部は、前記第1処理、前記第2処理および前記係数処理を繰り返すことによって予め設定された終了条件に達した場合、前記I個の決定変数の解の候補値を、前記問題の解として出力する。前記拡張ラグランジュ関数は、前記目的関数を含む目的関数項と、前記J個の連立一次方程式に対応するJ個の第1ラグランジュ項と、前記K個の連立一次不等式に対応するK個の第2ラグランジュ項と、ペナルティ項と、を含む。
第1実施形態に係る求解装置の機能構成を示す図である。 第1実施形態に係る求解装置の処理の流れを示すフローチャートである。 第2実施形態に係る求解装置の機能構成を示す図である。 第2実施形態に係る求解装置の処理の流れを示すフローチャートである。 求解装置のハードウェア構成を示す図である。
以下、図面を参照しながら実施形態に係る求解装置10について説明する。
(第1実施形態)
図1は、第1実施形態に係る求解装置10の機能構成を示す図である。
第1実施形態に係る求解装置10は、線形制約条件を含む0-1整数非凸二次計画問題の解を算出する。求解装置10は、プロセッサ、コンピュータまたはサーバ等がプログラムを実行することにより実現される。
より具体的には、求解装置10は、整数非凸二次関数である目的関数を最小化する問題の解を、線形制約を満たす条件下で算出する。目的関数は、それぞれが0または1となるI個(Iは2以上の整数)の決定変数を含む。
線形制約は、線形等式制約と線形不等式制約とを含む。線形等式制約は、J個(Jは0以上の整数)の連立一次方程式により表される。J個の連立一次方程式のそれぞれは、I個の決定変数のうちの少なくとも1つを変数として含む。なお、線形制約は、線形等式制約を含まなくてもよい。この場合、求解装置10は、J=0として、J個の連立一次方程式を取り扱う。
線形不等式制約は、K個(Kは1以上の整数)の連立一次不等式により表される。K個の連立一次不等式のそれぞれは、I個の決定変数のうちの少なくとも1つを変数として含む。
第1実施形態に係る求解装置10は、取得部22と、関数生成部24と、第1ソルバー26と、更新部30と、更新値記憶部32と、出力部34とを備える。
取得部22は、ユーザが操作手段を操作することにより入力された、目的関数、線形等式制約および線形不等式制約を取得する。取得部22は、これらの情報を、ネットワーク等を介して他の装置から受信してもよい。
関数生成部24は、取得部22により取得された情報に基づき、拡張ラグランジュ関数および従属変数制約を生成する。
拡張ラグランジュ関数は、問題の解を効率良く算出するために生成される関数である。拡張ラグランジュ関数は、I個の決定変数、および、K個の従属変数を含む。K個の従属変数のそれぞれは、問題の解を算出するために設定される。K個の従属変数のそれぞれは、実数の値となる。従属変数制約は、K個の従属変数のそれぞれの値を制約するK個の不等式により表される。なお、拡張ラグランジュ関数および従属変数制約については、さらなる詳細を、図2を参照して後述する。
第1ソルバー26は、制約条件を含まない0-1整数非凸二次計画問題の解を算出する。すなわち、第1ソルバー26は、0-1整数非凸二次関数を最小化する問題の解を算出する。第1ソルバー26は、イジング問題の解を算出するソルバーであってもよい。第1ソルバー26は、例えば、求解装置10を実現するプロセッサまたはコンピュータが0-1整数非凸二次計画問題の求解プログラムを実行することにより実現される。また、第1ソルバー26は、サーバ等により提供されてもよい。この場合、第1ソルバー26は、求解装置10の外部に実現されてもよい。第1ソルバー26が求解装置10の外部に実現される場合、求解装置10は、ネットワークを介して第1ソルバー26に対して目的関数を与えて、解の候補値を第1ソルバー26からネットワークを介して取得する。
更新部30は、第1処理、第2処理および係数処理を、予め設定された終了条件に達するまで繰り返す。更新部30は、第1処理、第2処理、係数処理の順で繰り返す。
第1処理は、第1関数を最小化するI個の決定変数の解の候補値を取得する処理である。更新部30は、第1処理を実行する毎にI個の決定変数の解の候補値を更新する。
第1関数は、拡張ラグランジュ関数に基づき生成されるI個の決定変数を含む関数である。第1関数は、拡張ラグランジュ関数に、K個の従属変数の解の候補値を代入した関数である。K個の従属変数の解の候補値は、直前の第2処理に基づく値である。また、最初の第2処理が実行される前に、最初の第1処理が実行される場合には、K個の従属変数の解の候補値は、予め設定された初期値となる。
第1関数は、整数非凸二次関数である。従って、更新部30は、第1処理において、第1関数を最小化する問題を第1ソルバー26に与えて、第1ソルバー26から問題の解として、I個の決定変数の解の候補値を取得する。なお、第1関数については、さらなる詳細を、図2を参照して後述する。
第2処理は、K個の不等式により表される従属変数制約を満たす条件の下で、第2関数を最小化するK個の従属変数の解の候補値を取得する処理である。更新部30は、第2処理を実行する毎にK個の従属変数の解の候補値を更新する。
第2関数は、拡張ラグランジュ関数に基づき生成されるK個の従属変数を含む関数である。第2関数は、拡張ラグランジュ関数に、I個の決定変数の解の候補値を代入した関数である。I個の決定変数の解の候補値は、直前の第1処理に基づき更新された値である。また、最初の第1処理が実行される前に最初の第2処理が実行される場合には、K個の決定変数の解の候補値は、予め設定された初期値となる。
K個の不等式は、K個の従属変数に対応する。K個の不等式のそれぞれは、対応する従属変数がとり得る最小値を表す。
第1実施形態において第2関数は、K個の従属変数のそれぞれが互いに独立している。第2関数のそれぞれの従属変数の項は、凸二次関数となる。従って、更新部30は、第2処理において、ソルバー等を用いずに、K個の不等式により表される従属変数制約を満たす条件の下で第2関数を最小化するK個の従属変数の解の候補値を演算処理により算出する。なお、第2関数については、さらなる詳細を、図2を参照して後述する。
係数処理は、拡張ラグランジュ関数に含まれる複数の係数のそれぞれを更新する処理である。更新部30は、直前の第1処理に基づき更新されたI個の決定変数の解の候補値、および、直前の第2処理に基づき更新されたK個の従属変数の解の候補値に基づき、拡張ラグランジュ関数に含まれる複数の係数のそれぞれを更新する。なお、拡張ラグランジュ関数に含まれる複数の係数のそれぞれは、最初の第1処理および最初の第2処理が実行される前においては、予め設定された初期値となる。なお、係数を更新する演算処理については、さらなる詳細を、図2を参照して後述する。
更新値記憶部32は、I個の決定変数の解の候補値、K個の従属変数の解の候補値、および、拡張ラグランジュ関数に含まれる複数の係数を記憶する。更新部30は、第1処理、第2処理および係数処理を実行する毎に、更新値記憶部32に記憶された対応する値を更新する。
出力部34は、更新部30が第1処理、第2処理および係数処理を繰り返すことによって、予め設定された終了条件に達した場合、I個の決定変数の解の候補値を、求解の対象となる線形制約条件を含む0-1整数非凸二次計画問題の解として出力する。
例えば、出力部34は、I個の決定変数の解の候補値が線形等式制約および線形不等式制約を満たしており、且つ、I個の決定変数の解の候補値を代入した目的関数の値が予め定められた閾値以下である場合、終了条件に達したと判断してもよい。これに加えてまたはこれに代えて、出力部34は、I個の決定変数の解の候補値が線形等式制約および線形不等式制約を満たしており、且つ、更新部30による繰り返し回数が予め設定された回数を超えた場合に、終了条件に達したと判断してもよい。なお、出力部34は、更新部30による繰り返し回数が予め設定された回数を超えても、I個の決定変数の解の候補値が線形等式制約および線形不等式制約を満たさない場合、解が算出できなかったことを示す情報を出力してもよい。
出力部34は、解を表示手段に表示することによりユーザに提示してもよい。また、出力部34は、解をネットワークを介して外部の装置に送信してもよい。
図2は、第1実施形態に係る求解装置10の処理の流れを示すフローチャートである。求解装置10は、図2に示す流れで処理を実行する。
まず、S11において、取得部22は、それぞれが0または1となるI個の決定変数を含む整数非凸二次関数である目的関数を取得する。
I個の決定変数は、式(1)のように表される。
Figure 2022142914000002
I個の決定変数それぞれは、0または1となり、式(2)のように制約される。
Figure 2022142914000003
目的関数は、式(3)のように表される。
Figure 2022142914000004
iは、1以上、I以下の整数であり、I個の決定変数のそれぞれに割り当てられるインデックスを表す。i´は、1以上、I以下の整数であり、iとは異なり、I個の決定変数のそれぞれに割り当てられるインデックスを表す。すなわち、I個の決定変数のうちの、xは、1番目の決定変数であり、xは、2番目の決定変数であり、xは、I番目の決定変数であり、xは、i番目の決定変数であり、xi´は、i´番目の決定変数である。
i,i´は、目的関数の2次項におけるi番目の決定変数とi´番目の決定変数との乗算値に乗算される係数である。Pi,i´は、実数である。Qは、目的関数の1次項におけるi番目の決定変数に乗算される係数である。Qは、実数である。
続いて、S12において、取得部22は、線形等式制約を取得する。具体的には、線形等式制約は、式(4)のJ個の連立一次方程式により表される。
Figure 2022142914000005
jは、1以上、J以下の整数であり、J個の連立一次方程式のそれぞれに割り当てられるインデックスを表す。Aj,iは、j番目の連立一次方程式におけるi番目の決定変数に乗算される係数である。Aj,iは、実数である。Bは、j番目の連立一次方程式における定数項である。Bは、実数である。
なお、取得部22は、線形等式制約を取得しなくてもよい。線形等式制約を取得しない場合、求解装置10は、J=0とし、jに関する演算を実行しない。
続いて、S13において、取得部22は、線形不等式制約を取得する。具体的には、線形不等式制約は、式(5)のK個の連立一次不等式により表される。
Figure 2022142914000006
kは、1以上、K以下の整数であり、K個の連立一次不等式のそれぞれに割り当てられるインデックスを表す。Ck,iは、k番目の連立一次不等式におけるi番目の決定変数に乗算される係数である。Ck,iは、実数である。Dは、k番目の連立一次不等式における定数項である。Dは、実数である。
続いて、S14において、関数生成部24は、目的関数、J個の連立一次方程式およびK個の連立一次不等式に基づき、拡張ラグランジュ関数を生成する。拡張ラグランジュ関数は、式(6)により表される。
Figure 2022142914000007
拡張ラグランジュ関数は、目的関数項と、J個の第1ラグランジュ項と、K個の第2ラグランジュ項と、ペナルティ項と、を含む。
目的関数項は、目的関数を含む。目的関数項は、式(7)により表される。
Figure 2022142914000008
J個の第1ラグランジュ項は、J個の連立一次方程式に対応する。J個の第1ラグランジュ項を総加算した式は、式(8)により表される。
Figure 2022142914000009
関数生成部24は、J個の第1ラグランジュ係数を設定する。λは、J個の第1ラグランジュ係数のうちのj番目の第1ラグランジュ係数である。j番目の第1ラグランジュ係数は、J個の第1ラグランジュ項のうちの、j番目の第1ラグランジュ項に含まれる。J個の第1ラグランジュ係数のそれぞれは、実数である。
J個の第1ラグランジュ項のそれぞれは、J個の連立一次方程式のうちの対応する連立一次方程式とI個の決定変数の解の候補値との誤差を表す関数に、J個の第1ラグランジュ係数のうちの対応する第1ラグランジュ係数を乗じた関数である。すなわち、J個の第1ラグランジュ項のそれぞれは、I個の決定変数の解の候補値が、対応する線形等式制約を満たすと0となり、対応する線形等式制約を満たさないとマイナス方向またはプラス方向にずれる関数である。
なお、式(8)は、先頭に-1が乗じられている。しかし、式(8)は、-1が乗じられていなくてもよい。
K個の第2ラグランジュ項は、K個の連立一次不等式に対応する。K個の第2ラグランジュ項を総加算した式は、式(9)により表される。
Figure 2022142914000010
関数生成部24は、K個の第2ラグランジュ係数を設定する。λ´は、K個の第2ラグランジュ係数のうちのk番目の第2ラグランジュ係数である。k番目の第2ラグランジュ係数は、K個の第2ラグランジュ項のうちの、k番目の第2ラグランジュ項に含まれる。K個の第2ラグランジュ係数のそれぞれは、実数である。
関数生成部24は、K個の従属変数を設定する。zは、K個の従属変数のうちのk番目の従属変数である。従属変数は、実数の値をとる。
また、関数生成部24は、K個の代替方程式を設定する。k番目の従属変数は、K個の代替方程式のうちのk番目の代替方程式に含まれる。K個の代替方程式は、K個の連立一次不等式に対応する。K個の代替方程式のそれぞれは、K個の連立一次不等式のうちの対応する連立一次不等式の不等号を等号に置き換え、且つ、定数項をK個の従属変数のうちの対応する従属変数に置き換えた方程式である。式(9)の例の場合、k番目の代替方程式は、式(5)の不等号を等号に置き換え、且つ、Dをzに置き換えた方程式となる。
K個の第2ラグランジュ項のそれぞれは、K個の代替方程式のうちの対応する代替方程式と、I個の決定変数の解の候補値との誤差を表す関数に、K個の第2ラグランジュ係数のうちの対応する第2ラグランジュ係数を乗じた関数である。すなわち、K個の第2ラグランジュ項のそれぞれは、I個の決定変数の解の候補値が、対応する代替方程式を満たすと0となり、対応する代替方程式を満たさないとマイナス方向またはプラス方向にずれる関数である。
なお、式(9)は、先頭に-1が乗じられている。しかし、式(9)は、-1が乗じられていなくてもよい。
ペナルティ項は、式(10)により表される。
Figure 2022142914000011
μは、ペナルティ係数である。ペナルティ係数は、0より大きい実数である。ペナルティ項は、J個の第1距離関数と、K個の第2距離関数との合計に、ペナルティ係数を乗じた関数である。
J個の第1距離関数は、J個の連立一次方程式に対応する。J個の第1距離関数のそれぞれは、J個の連立一次方程式のうちの対応する連立一次方程式とI個の決定変数の解の候補値との間の距離(第1距離)を表す関数である。例えば、式(10)の例の場合、J個の第1距離関数のそれぞれは、対応する連立一次方程式とI個の決定変数の解の候補値との誤差を二乗した関数である。
K個の第2距離関数は、K個の代替方程式に対応する。K個の第2距離関数のそれぞれは、K個の代替方程式のうちの対応する代替方程式とI個の決定変数の解の候補値との間の距離(第2距離)を表す関数である。例えば、式(10)の例の場合、K個の第2距離関数のそれぞれは、対応する代替方程式とI個の決定変数の解の候補値との誤差を二乗した関数である。すなわち、ペナルティ項は、第1距離と第2距離との合計がプラスになるほど、プラス方向にずれる関数である。
なお、式(10)は、先頭に1/2が乗じられている。しかし、式(10)は、0より大きい実数であれば、1/2以外の値が乗じられてもよい。
続いて、S15において、関数生成部24は、従属変数制約を生成する。従属変数制約は、K個の従属変数の制約条件を表す。
従属変数制約は、K個の不等式により表される。K個の不等式は、K個の従属変数に対応する。K個の不等式のそれぞれは、対応する従属変数が、定数以下であることを表す。具体的には、従属変数制約は、式(11)により表される。
Figure 2022142914000012
すなわち、K個の不等式のそれぞれは、K個の従属変数のうちの対応する従属変数が、K個の連立一次不等式のうちの対応する連立一次不等式における定数項以下であることを表す。式(11)の例の場合、K個の不等式のそれぞれは、式(5)の決定変数の1次項(ΣCk,i・x)をzに置き換えた不等式となる。
続いて、S16において、更新部30は、nを0に初期化する。更新部30は、S18からS26までの処理を繰り返す。nは、S18からS26までの処理の実行回数を表す。nは、初期値が0であり、1ずつ増加する。
続いて、S17において、更新部30は、最初の第1処理、最初の第2処理および最初の係数処理に先だって、I個の決定変数の解の候補値のそれぞれ、K個の従属変数の解の候補値のそれぞれ、J個の第1ラグランジュ係数のそれぞれ、K個の第2ラグランジュ係数のそれぞれ、および、ペナルティ係数に対して、予め定められた初期値を代入する。
なお、I個の決定変数の解の候補値のそれぞれ、K個の従属変数の解の候補値のそれぞれ、J個の第1ラグランジュ係数のそれぞれ、K個の第2ラグランジュ係数のそれぞれ、および、ペナルティ係数は、S18からS26までのループ処理毎に更新がされる。
本例においては、x[n]は、n回目のループ処理の後のI個の決定変数の解の候補値を表す。z[n]は、n回目のループ処理の後のK個の従属変数の解の候補値を表す。λ[n]は、n回目のループ処理の後の第1ラグランジュ係数を表す。λ´[n]は、n回目のループ処理の後の第2ラグランジュ係数を表す。μ[n]は、n回目のループ処理の後のペナルティ係数を表す。なお、x[0]は、x[n]の初期値を表す。z[0]は、z[n]の初期値を表す。λ[0]は、λ[n]の初期値を表す。λ´[0]は、λ´[n]の初期値を表す。μ[0]は、μ[n]の初期値を表す。
例えば、更新部30は、これらの各値を、式(12)のように初期化する。
Figure 2022142914000013
μは、0より大きい予め定められた実数である。式(12)のmin(A,B)は、AまたはBのうち何れか小さい方の値を選択する関数を表す。
S18において、更新部30は、拡張ラグランジュ関数に基づき、I個の決定変数を含む第1関数を生成する。n+1回目のループ処理において生成される第1関数は、式(13)により表される。
Figure 2022142914000014
すなわち、n+1回目のループ処理において生成される第1関数は、直前のループ処理(n回目のループ処理)の後における、K個の従属変数の解の候補値であるz[n]、J個の第1ラグランジュ係数であるλ[n]、K個の第2ラグランジュ係数であるλ´[n]、および、ペナルティ係数であるμ[n]を式(6)の拡張ラグランジュ関数に代入した関数である。第1関数は、I個の決定変数を含む整数非凸二次関数となる。なお、1回目のループ処理においては、直前のループ処理の後のz[n]、λ[n]、λ´[n]、および、μ[n]は、S17で代入した初期値となる。
続いて、S19において、更新部30は、第1処理を実行する。すなわち、更新部30は、第1関数を最小化するI個の決定変数の解の候補値を取得する。例えば、更新部30は、式(14)に示す関数を実行する。
Figure 2022142914000015
minは、以下に続く関数を最小化する演算子である。argは、xの値を取得する関数である。更新部30は、式(14)の実行に応じて、第1関数を最小化する問題を第1ソルバー26に与えて、第1ソルバー26から問題の解として、I個の決定変数の解の候補値を取得する。
続いて、S20において、更新部30は、終了条件に達したか否かを判断する。更新部30は、終了条件に達した場合、処理をS27に進める。更新部30は、終了条件に達していない場合、処理をS21に進める。
続いて、S21において、更新部30は、更新値記憶部32に記憶されているI個の決定変数の解の候補値のそれぞれを更新する。なお、第1ソルバー26は、I個の決定変数の解の候補値を、複数組分の出力する場合がある。例えば、第1ソルバー26は、目的関数の値が最小値から所定番目までの所定組のI個の決定変数の解の候補値を出力する場合がある。
このような場合、更新部30は、複数組のI個の決定変数の解の候補値に基づき、一組のI個の決定変数の解の候補値を算出してもよい。そして、更新部30は、n+1回目のループ処理におけるI個の決定変数の解の候補値のそれぞれ(x[n+1])を、複数組のI個の決定変数の解の候補値に基づき算出した値に置き換えてもよい。例えば、更新部30は、決定変数毎に、所定個の候補値の平均値を算出する。そして、更新部30は、I個の決定変数の解の候補値のそれぞれを、対応する所定個の決定変数の解の候補値の平均値に置き換えてもよい。
S22において、更新部30は、拡張ラグランジュ関数に基づき、K個の従属変数を含む第2関数を生成する。n+1回目のループ処理において生成される第2関数は、式(15)により表される。
Figure 2022142914000016
すなわち、n+1回目のループ処理において生成される第2関数は、直前のS21で更新されたI個の決定変数の解の候補値であるx[n+1]、並びに、直前のループ処理(n回目のループ処理)の後のJ個の第1ラグランジュ係数であるλ[n]、K個の第2ラグランジュ係数であるλ´[n]およびペナルティ係数であるμ[n]を式(6)の拡張ラグランジュ関数に代入した関数である。第2関数は、K個の従属変数を含む凸二次関数となる。なお、1回目のループ処理においては、直前のループ処理において更新された、λ[n]、λ´[n]、および、μ[n]は、S17で代入した初期値となる。
続いて、S23において、更新部30は、第2処理を実行する。すなわち、更新部30は、K個の不等式により表される従属変数制約を満たす条件の下で、第2関数を最小化するK個の従属変数の解の候補値を取得する。例えば、更新部30は、式(16)に示す関数を実行する。
Figure 2022142914000017
argは、zの値を取得する関数である。
ここで、第2関数は、凸二次関数である。そして、第2関数に含まれるK個の従属変数であるzのそれぞれは、他の変数から独立している。このため、K個の従属変数のそれぞれは、第2関数を偏微分した関数が0となる解が最小値となる。
従って、更新部30は、K個の従属変数のそれぞれについて、微分関数が0となる値が対応する不等式を満たしている場合、微分関数を0とする値を候補値として取得する。また、更新部30は、K個の従属変数のそれぞれについて、微分関数が0となる値が対応する不等式を満たしていない場合、対応する不等式を満たす最小値を候補値として取得する。
例えば、更新部30は、式(17)に表される関数により、第2関数に含まれるK個の従属変数のそれぞれの最小値を取得することができる。
Figure 2022142914000018
なお、min(A,B)は、AまたはBのうち何れか小さい方の値を選択する関数を表す。
続いて、S24において、更新部30は、更新値記憶部32に記憶されているK個の従属変数の解の候補値のそれぞれを更新する。
続いて、S25において、更新部30は、係数処理を実行する。すなわち、更新部30は、更新値記憶部32に記憶されているJ個の第1ラグランジュ係数、K個の第2ラグランジュ係数およびペナルティ係数を更新する。
具体的には、更新部30は、直前のループ処理において更新されたJ個の第1ラグランジュ係数のそれぞれから、対応する連立一次方程式とI個の決定変数の解の候補値との誤差に応じた値を減じる。より具体的には、更新部30は、n+1回目のループ処理におけるJ個の第1ラグランジュ係数(λ[n+1])として、式(18)に示す値を代入する。
Figure 2022142914000019
また、具体的には、更新部30は、直前のループ処理において更新されたK個の第2ラグランジュ係数のそれぞれから、対応する代替方程式とI個の決定変数の解の候補値との誤差に応じた値を減じる。より具体的には、更新部30は、n+1回目のループ処理におけるK個の第2ラグランジュ係数(λ´[n+1])として、式(19)に示す値を代入する。
Figure 2022142914000020
また、具体的には、更新部30は、直前のループ処理において更新されたペナルティ係数を増加させる。より具体的には、更新部30は、n+1回目のループ処理におけるペナルティ(μ[n+1])として、式(20)に示す値を代入する。
Figure 2022142914000021
なお、式(20)におけるαは、予め定められた値であって、正の実数である。
続いて、S26において、更新部30は、nに1を加算する。そして、更新部30は、S26の処理を終えると、処理をS18に戻し、S18からS26までの処理を、S20の終了条件に達するまで繰り返す。更新部30は、S20で終了条件に達した場合(S20のYes)、処理をS27に進める。
S27において、出力部34は、S19で取得したI個の決定変数の解の候補値が線形等式制約および線形不等式制約を満たしている場合、I個の決定変数の解の候補値を、求解の対象となる0-1整数非凸二次計画問題の解として出力する。また、出力部34は、S19で取得したI個の決定変数の解の候補値が線形等式制約および線形不等式制約を満たしていない場合、求解の対象となる0-1整数非凸二次計画問題の解が算出できなかったことを示す情報を出力する。
以上のような第1実施形態に係る求解装置10は、制約条件を含まない0-1整数非凸二次計画問題の解を取得する第1処理と、凸二次関数の解を取得する第2処理とを交互に繰り返す。制約条件を含まない0-1整数非凸二次計画問題は、イジングマシン等のソルバーにより、良い解を簡易に取得可能である。また、凸二次関数は、一次方程式を解くことにより、非常に容易に最適解を取得可能である。従って、求解装置10は、第1処理と第2処理とを繰り返すことにより、線形制約条件を含む0-1整数非凸二次計画問題について、良い解を効率良く算出することができる。
また、第1実施形態に係る求解装置10は、目的関数に、J個の第1ラグランジュ項と、K個の第2ラグランジュ項と、ペナルティ項とを加算した拡張ラグランジュ関数を用いて、I個の決定変数の解を算出する。J個の第1ラグランジュ項およびK個の第2ラグランジュ項は、制約の周辺での目的関数の傾きを打ち消すような働きをする。従って、第1実施形態に係る求解装置10は、ペナルティ項に含まれるペナルティ係数を、目的関数に含まれる係数であるPi,i´およびQよりも大きくしなくても、制約条件を満たす解を取得することができる。従って、第1実施形態に係る求解装置10は、第1ソルバー26の計算能力を、実行可能解を取得するためでなく良い解を探すために多く費やさせることができる。よって、求解装置10は、良い解を取得する確率を上げることができる。
また、第1実施形態に係る求解装置10は、第1ラグランジュ係数、第2ラグランジュ係数およびペナルティ係数を簡易な演算により更新する。これにより、求解装置10は、第1ラグランジュ係数、第2ラグランジュ係数およびペナルティ係数を容易に更新することができる。
(第2実施形態)
第2実施形態に係る求解装置10は、線形制約条件を含む、0-1整数非凸二次計画および連続凸計画を組み合わせた問題の解を算出する。第2実施形態は、第1実施形態と同一または対応する係数、変数、機能ブロックおよびステップについて、同一の記号または符号を付けて適宜説明を省略し、相違点を中心に説明をする。
図3は、第2実施形態に係る求解装置10の機能構成を示す図である。
第2実施形態に係る求解装置10は、整数非凸二次関数と連続凸関数とを加算した目的関数を最小化する問題の解を、線形制約を満たす条件下で算出する。例えば、連続凸関数は、連続凸二次関数である。整数非凸二次関数は、それぞれが0または1となるI個の第1決定変数を含む。連続凸関数は、それぞれが実数となるM個(Mは2以上の整数)の第2決定変数を含む。
線形制約は、線形等式制約と線形不等式制約とを含む。線形等式制約は、J個の連立一次方程式により表される。J個の連立一次方程式のそれぞれは、I個の第1決定変数およびM個の第2決定変数のうちの少なくとも1つを変数として含む。なお、線形制約は、線形等式制約を含まなくてもよい。この場合、求解装置10は、J=0として、J個の連立一次方程式を取り扱う。
線形不等式制約は、K個の連立一次不等式により表される。K個の連立一次不等式のそれぞれは、I個の第1決定変数およびM個の第2決定変数のうちの少なくとも1つを変数として含む。
第2実施形態に係る求解装置10は、第1実施形態の構成と比較して、第2ソルバー42をさらに備える。
第2ソルバー42は、変数の範囲を制約する条件の下で、連続凸計画問題の解を算出する。例えば、目的関数に含まれる連続凸関数が連続凸二次関数である場合、第2ソルバー42は、変数の範囲を制約する条件の下で、連続凸二次計画問題の解を算出する。第2ソルバー42は、例えば、求解装置10を実現するプロセッサまたはコンピュータが連続凸計画問題の求解プログラムを実行することにより実現される。また、第2ソルバー42は、サーバ等により提供されてもよい。この場合、第2ソルバー42は、求解装置10の外部に実現されてもよい。第2ソルバー42は、一例として、OSQP(Operator Splitting Quadratic Program)と呼ばれるソルバープログラムをコンピュータが実行することにより実現することができる。第2ソルバー42が求解装置10の外部に実現される場合、求解装置10は、ネットワークを介して第2ソルバー42に対して連続凸関数(例えば連続凸二次関数)を与えて、解の候補値を第2ソルバー42からネットワークを介して取得する。
取得部22は、目的関数、線形等式制約および線形不等式制約を取得する。関数生成部24は、取得部22により取得された情報に基づき、拡張ラグランジュ関数および従属変数制約を生成する。
拡張ラグランジュ関数は、解を効率良く算出するために生成される関数である。拡張ラグランジュ関数は、I個の第1決定変数、M個の第2決定変数、および、K個の従属変数を含む。
更新部30は、第1処理、第2処理および係数処理を、予め設定された終了条件に達するまで繰り返す。
第1処理は、第1関数を最小化するI個の第1決定変数の解の候補値を取得する処理である。更新部30は、第1処理を実行する毎にI個の第1決定変数の解の候補値を更新する。
第1関数は、拡張ラグランジュ関数に基づき生成されるI個の第1決定変数を含む関数である。第1関数は、拡張ラグランジュ関数に、M個の第2決定変数の候補値およびK個の従属変数の解の候補値を代入した関数である。M個の第2決定変数の解の候補値およびK個の従属変数の解の候補値は、直前の第2処理に基づく値である。また、最初の第2処理が実行される前に、最初の第1処理が実行される場合には、M個の第2決定変数の解の候補値およびK個の従属変数の解の候補値は、予め設定された初期値となる。
第1関数は、整数非凸二次関数である。従って、更新部30は、第1処理において、第1関数を最小化する問題を第1ソルバー26に与えて、第1ソルバー26から問題の解として、I個の第1決定変数の解の候補値を取得する。
第2処理は、K個の不等式により表される従属変数制約を満たす条件の下で、第2関数を最小化するM個の第2決定変数の解の候補値およびK個の従属変数の解の候補値を取得する処理である。更新部30は、第2処理を実行する毎にM個の第2決定変数の解の候補値およびK個の従属変数の解の候補値を更新する。
第2関数は、拡張ラグランジュ関数に基づき生成されるM個の第2決定変数およびK個の従属変数を含む関数である。第2関数は、拡張ラグランジュ関数に、I個の第1決定変数の解の候補値を代入した関数である。I個の第1決定変数の解の候補値は、直前の第1処理に基づき更新された値である。また、最初の第1処理が実行される前に最初の第2処理が実行される場合には、K個の第1決定変数の解の候補値は、予め設定された初期値となる。
K個の不等式は、K個の従属変数に対応する。K個の不等式のそれぞれは、対応する従属変数がとり得る最小値を表す。
第2関数は、連続凸関数である。例えば、第2関数は、連続凸二次関数である。従って、更新部30は、第2処理において、K個の不等式の条件の下で第2関数を最小化する問題を第2ソルバー42に与えて、第2ソルバー42から問題の解として、M個の第2決定変数の解の候補値およびK個の従属変数の解の候補値を取得する。
係数処理は、拡張ラグランジュ関数に含まれる複数の係数のそれぞれを更新する処理である。更新部30は、直前の第1処理に基づき更新されたI個の第1決定変数の解の候補値、直前の第2処理に基づき更新されたM個の第2決定変数の解の候補値、および、直前の第2処理に基づき更新されたK個の従属変数の解の候補値に基づき、拡張ラグランジュ関数に含まれる複数の係数のそれぞれを更新する。なお、拡張ラグランジュ関数の複数の係数のそれぞれは、最初の第1処理および最初の第2処理が実行される前において、予め設定された初期値となる。
更新値記憶部32は、I個の第1決定変数の解の候補値、M個の第2決定変数の解の候補値、K個の従属変数の解の候補値、および、拡張ラグランジュ関数に含まれる複数の係数を記憶する。更新部30は、第1処理、第2処理および係数処理を実行する毎に、更新値記憶部32に記憶された対応する値を更新する。
出力部34は、更新部30が第1処理、第2処理および係数処理を繰り返すことによって、予め設定された終了条件に達した場合、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値を、問題の解として出力する。
図4は、第2実施形態に係る求解装置10の処理の流れを示すフローチャートである。求解装置10は、図4に示す流れで処理を実行する。
まず、S11において、取得部22は、それぞれが0または1となるI個の第1決定変数を含む整数非凸二次関数と、それぞれが実数となるM個の第2決定変数を含む連続凸関数とを加算した目的関数を取得する。連続凸関数は、例えば、連続凸二次関数である。
I個の第1決定変数およびM個の第2決定変数は、式(21)のように表される。I個の第1決定変数は、xである。M個の第2決定変数は、yである。
Figure 2022142914000022
なお、I個の第1決定変数は、0または1となるので、第1実施形態のI個の決定変数と同様である。従って、第2実施形態において、I個の第1決定変数は、xと表している。
M個の第2決定変数それぞれは、実数であり、式(22)のように制約される。
Figure 2022142914000023
目的関数は、式(23)のように表される。
Figure 2022142914000024
mは、1以上、M以下の整数であり、M個の第2決定変数のそれぞれに割り当てられるインデックスを表す。すなわち、M個の第2決定変数のうちの、yは、1番目の第2決定変数であり、yは、2番目の第2決定変数であり、yは、M番目の第2決定変数であり、yは、m番目の第2決定変数である。
R(y)は、連続凸関数を表す。R(y)は、例えば、連続凸二次関数である。
続いて、S12において、取得部22は、線形等式制約を取得する。具体的には、線形等式制約は、式(24)のJ個の連立一次方程式により表される。
Figure 2022142914000025
j,mは、j番目の連立一次方程式におけるm番目の第2決定変数に乗算される係数である。Ej,mは、実数である。なお、取得部22は、線形等式制約を取得しなくてもよい。線形等式制約を取得しない場合、求解装置10は、J=0とし、jに関する演算を実行しない。
続いて、S13において、取得部22は、線形不等式制約を取得する。具体的には、線形不等式制約は、式(25)のK個の連立一次不等式により表される。
Figure 2022142914000026
k,mは、k番目の連立一次不等式におけるm番目の第2決定変数に乗算される係数である。Fk,mは、実数である。
続いて、S14において、関数生成部24は、目的関数、J個の連立一次方程式およびK個の連立一次不等式に基づき、拡張ラグランジュ関数を生成する。拡張ラグランジュ関数は、式(26)により表される。
Figure 2022142914000027
拡張ラグランジュ関数は、目的関数項と、J個の第1ラグランジュ項と、K個の第2ラグランジュ項と、ペナルティ項と、を含む。
目的関数項は、目的関数を含む。目的関数項は、式(27)により表される。
Figure 2022142914000028
J個の第1ラグランジュ項は、J個の連立一次方程式に対応する。J個の第1ラグランジュ項を総加算した式は、式(28)により表される。
Figure 2022142914000029
J個の第1ラグランジュ項のそれぞれは、J個の連立一次方程式のうちの対応する連立一次方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との誤差を表す関数に、J個の第1ラグランジュ係数のうちの対応する第1ラグランジュ係数を乗じた関数である。すなわち、J個の第1ラグランジュ項のそれぞれは、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値が、対応する線形等式制約を満たすと0となり、対応する線形等式制約を満たさないとマイナス方向またはプラス方向にずれる関数である。
なお、式(28)は、先頭に-1が乗じられている。しかし、式(28)は、-1が乗じられていなくてもよい。
K個の第2ラグランジュ項は、K個の連立一次不等式に対応する。K個の第2ラグランジュ項を総加算した式は、式(29)により表される。
Figure 2022142914000030
関数生成部24は、K個の代替方程式を設定する。K個の代替方程式のそれぞれは、K個の連立一次不等式のうちの対応する連立一次不等式の不等号を等号に置き換え、且つ、定数項をK個の従属変数のうちの対応する従属変数に置き換えた方程式である。式(29)の例の場合、k番目の代替方程式は、式(25)の不等号を等号に置き換え、且つ、Dをzに置き換えた方程式となる。
K個の第2ラグランジュ項のそれぞれは、K個の代替方程式のうちの対応する代替方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との誤差を表す関数に、K個の第2ラグランジュ係数のうちの対応する第2ラグランジュ係数を乗じた関数である。すなわち、K個の第2ラグランジュ項のそれぞれは、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値が、対応する代替方程式を満たすと0となり、対応する代替方程式を満たさないとマイナス方向またはプラス方向にずれる関数である。
なお、式(29)は、先頭に-1が乗じられている。しかし、式(29)は、-1が乗じられていなくてもよい。
ペナルティ項は、式(30)により表される。
Figure 2022142914000031
ペナルティ項は、J個の第1距離関数と、K個の第2距離関数との合計に、ペナルティ係数を乗じた関数である。J個の第1距離関数のそれぞれは、J個の連立一次方程式のうちの対応する連立一次方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との間の距離(第1距離)を表す関数である。例えば、式(30)の例の場合、J個の第1距離関数のそれぞれは、対応する連立一次方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との誤差を二乗した関数である。
K個の第2距離関数のそれぞれは、K個の代替方程式のうちの対応する代替方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との間の距離(第2距離)を表す関数である。例えば、式(30)の例の場合、K個の第2距離関数のそれぞれは、対応する代替方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との誤差を二乗した関数である。すなわち、ペナルティ項は、第1距離と第2距離との合計がプラスになるほど、プラス方向にずれる関数である。
なお、式(30)は、先頭に1/2が乗じられている。しかし、式(30)は、0より大きい実数であれば、1/2以外の値が乗じられてもよい。
続いて、S15において、関数生成部24は、K個の不等式により表される従属変数制約を生成する。従属変数制約は、式(31)により表される。
Figure 2022142914000032
K個の不等式のそれぞれは、K個の従属変数のうちの対応する従属変数が、K個の連立一次不等式のうちの対応する連立一次不等式における定数項以下であることを表す。式(31)の例の場合、K個の不等式のそれぞれは、式(25)の左辺をzに置き換えた不等式となる。
続いて、S16において、更新部30は、nを0に初期化する。
続いて、S17において、更新部30は、最初の第1処理、最初の第2処理および最初の係数処理に先だって、I個の第1決定変数の解の候補値のそれぞれ、M個の第2決定変数の解の候補値のそれぞれ、K個の従属変数の解の候補値のそれぞれ、J個の第1ラグランジュ係数のそれぞれ、K個の第2ラグランジュ係数のそれぞれ、および、ペナルティ係数に対して、予め定められた初期値を代入する。
本例においては、y[n]は、n回目のループ処理の後のM個の第2決定変数の解の候補値を表す。なお、y[0]は、y[n]の初期値を表す。例えば、更新部30は、これらの各値を、式(32)のように初期化する。
Figure 2022142914000033
なお、argy,zは、yおよびzの値を取得する関数である。更新部30は、式(32)におけるz[n]およびy[n]を、演算により算出可能であれば、演算により算出してもよいし、式(32)を満たすz[n]およびy[n]をユーザから受け付けたり、別の装置から取得してもよい。また、更新部30は、式(32)におけるz[n]およびy[n]を、後述するS22およびS23と同様に、第2関数を生成し、生成した第2関数を最小化する問題を第2ソルバー42に与えて、第2ソルバー42から問題の解として取得してもよい。
S18において、更新部30は、拡張ラグランジュ関数に基づき、I個の第1決定変数を含む第1関数を生成する。n+1回目のループ処理において生成される第1関数は、式(33)により表される。
Figure 2022142914000034
すなわち、n+1回目のループ処理において生成される第1関数は、直前のループ処理(n回目のループ処理)の後における、M個の第2決定変数の解の候補値であるy[n]、K個の従属変数の解の候補値であるz[n]、J個の第1ラグランジュ係数であるλ[n]、K個の第2ラグランジュ係数であるλ´[n]、および、ペナルティ係数であるμ[n]を、式(26)の拡張ラグランジュ関数に代入した関数である。第1関数は、I個の第1決定変数を含む整数非凸二次関数となる。なお、1回目のループ処理においては、直前のループ処理の後のy[n]、z[n]、λ[n]、λ´[n]、および、μ[n]は、S17で代入した初期値となる。
続いて、S19において、更新部30は、第1処理を実行する。すなわち、更新部30は、第1関数を最小化するI個の第1決定変数の解の候補値を取得する。例えば、更新部30は、式(34)に示す関数を実行する。
Figure 2022142914000035
更新部30は、式(34)を実行することによって、第1関数を最小化する問題を第1ソルバー26に与えて、第1ソルバー26から問題の解として、I個の第1決定変数の解の候補値を取得する。
続いて、S20において、更新部30は、終了条件に達したか否かを判断する。更新部30は、終了条件に達した場合、処理をS27に進める。更新部30は、終了条件に達していない場合、処理をS21に進める。
続いて、S21において、更新部30は、更新値記憶部32に記憶されているI個の第1決定変数の解の候補値のそれぞれを更新する。
S22において、更新部30は、拡張ラグランジュ関数に基づき、M個の第2決定変数およびK個の従属変数を含む第2関数を生成する。n+1回目のループ処理において生成される第2関数は、式(35)により表される。
Figure 2022142914000036
すなわち、n+1回目のループ処理において生成される第2関数は、直前のS21で更新されたI個の第1決定変数の解の候補値であるx[n+1]、並びに、直前のループ処理(n回目のループ処理)の後のJ個の第1ラグランジュ係数であるλ[n]、K個の第2ラグランジュ係数であるλ´[n]およびペナルティ係数であるμ[n]を式(26)の拡張ラグランジュ関数に代入した関数である。なお、1回目のループ処理においては、直前のループ処理において更新された、λ[n]、λ´[n]、および、μ[n]は、S17で代入した初期値となる。
続いて、S23において、更新部30は、第2処理を実行する。すなわち、更新部30は、K個の不等式により表される従属変数制約を満たす条件の下で、第2関数を最小化するM個の第2決定変数の解の候補値およびK個の従属変数の解の候補値を取得する。例えば、更新部30は、第2関数を最小化する問題を第2ソルバー42に与えて、第2ソルバー42から問題の解として、M個の第2決定変数の解の候補値およびI個の第1決定変数の解の候補値を取得する。例えば、更新部30は、式(36)に示す関数を実行する。
Figure 2022142914000037
なお、argy,zは、yおよびzの値を取得する関数である。
続いて、S24において、更新部30は、更新値記憶部32に記憶されているM個の第2決定変数の解の候補値のそれぞれおよびK個の従属変数の解の候補値のそれぞれを更新する。
続いて、S25において、更新部30は、係数処理を実行する。すなわち、更新部30は、更新値記憶部32に記憶されているJ個の第1ラグランジュ係数、K個の第2ラグランジュ係数およびペナルティ係数を更新する。
具体的には、更新部30は、直前のループ処理において更新されたJ個の第1ラグランジュ係数のそれぞれから、対応する連立一次方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との誤差に応じた値を減じる。より具体的には、更新部30は、n+1回目のループ処理におけるJ個の第1ラグランジュ係数(λ[n+1])として、式(37)に示す値を代入する。
Figure 2022142914000038
また、具体的には、更新部30は、直前のループ処理において更新されたK個の第2ラグランジュ係数のそれぞれから、対応する代替方程式と、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値との誤差に応じた値を減じる。より具体的には、更新部30は、n+1回目のループ処理におけるK個の第2ラグランジュ係数(λ´[n+1])として、式(38)に示す値を代入する。
Figure 2022142914000039
また、具体的には、更新部30は、直前のループ処理において更新されたペナルティ係数を増加させる。より具体的には、更新部30は、n+1回目のループ処理におけるペナルティ(μ[n+1])として、式(39)に示す値を代入する。
Figure 2022142914000040
続いて、S26において、更新部30は、nに1を加算する。そして、更新部30は、S26の処理を終えると、処理をS18に戻し、S18からS26までの処理を、S20の終了条件に達するまで繰り返す。更新部30は、S20で終了条件に達した場合(S20のYes)、処理をS27に進める。
S27において、出力部34は、S19で取得したI個の第1決定変数の解の候補値およびS23で取得したM個の第2決定変数の解の候補値が線形等式制約および線形不等式制約を満たしている場合、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値を、求解の対象となる0-1整数非凸二次計画問題の解として出力する。また、出力部34は、I個の第1決定変数の解の候補値およびM個の第2決定変数の解の候補値が線形等式制約および線形不等式制約を満たしていない場合、求解の対象となる0-1整数非凸二次計画問題の解が算出できなかったことを示す情報を出力する。
以上のような第2実施形態に係る求解装置10は、制約条件を含まない0-1整数非凸二次計画問題の解を取得する第1処理と、連続凸関数の解を取得する第2処理とを交互に繰り返す。制約条件を含まない0-1整数非凸二次計画問題は、イジングマシン等のソルバーにより、良い解を簡易に取得可能である。また、連続凸計画問題は、既存のソルバーにより、良い解を簡易に取得可能である。従って、求解装置10は、第1処理と第2処理とを繰り返すことにより、線形制約条件を含む0-1整数非凸二次計画問題と連続凸計画問題とを組み合わせた問題に対して、良い解を効率良く算出することができる。
また、以上のような第2実施形態に係る求解装置10は、目的関数に、J個の第1ラグランジュ項と、K個の第2ラグランジュ項と、ペナルティ項とを加算した拡張ラグランジュ関数を用いて、I個の第1決定変数の解を算出する。J個の第1ラグランジュ項およびK個の第2ラグランジュ項は、制約の周辺での目的関数の傾きを打ち消すような働きをする。従って、第2実施形態に係る求解装置10は、ペナルティ項に含まれるペナルティ係数を、目的関数に含まれる係数であるPi,i´およびQよりも、大きくしなくても、制約条件を満たす解を取得することができる。従って、第2実施形態に係る求解装置10は、第1ソルバー26の計算能力を、実行可能解を取得するためでなく良い解を探すために多く費やさせることができる。よって、求解装置10は、良い解を取得する確率を上げることができる。
また、第2実施形態に係る求解装置10は、第1ラグランジュ係数、第2ラグランジュ係数およびペナルティ係数を簡易な演算により更新する。これにより、求解装置10は、第1ラグランジュ係数、第2ラグランジュ係数およびペナルティ係数を容易に更新することができる。
(変形例)
第1実施形態に係る拡張ラグランジュ関数に含まれるK個の第2ラグランジュ項は、式(40)のように表されてもよい。
Figure 2022142914000041
式(40)のφ(x)は、活性化関数を表す。活性化関数は、例えば、式(41)に示すようなReLU関数である。
Figure 2022142914000042
φ(x)は、xが閾値以上であるか、x閾値より小さいかに応じて、xをそのまま出力するか、0を出力するかを切り替える。閾値は、どのような値であってもよい。
また、このような場合、更新部30は、S25の係数処理において、第2ラグランジュ係数を式(42)に示すように、活性化関数を用いて更新する。
Figure 2022142914000043
このような拡張ラグランジュ関数は、第1ソルバー26が決定変数の値に応じて、最適値を探索するか否かを切り替えるソルバーである場合に有効となる。また、活性化関数は、第2実施形態に係る拡張ラグランジュ関数の第2ラグランジュ項に適用されてもよい。
(ハードウェア構成)
図5は、求解装置10のハードウェアブロック図である。求解装置10は、一例として、図5に示すような一般のコンピュータ(情報処理装置)と同様のハードウェア構成により実現される。求解装置10は、図5に示すような1つのコンピュータまたはサーバにより実現されてもよいし、協働して動作する複数のコンピュータまたはサーバにより実現されてもよい。また、求解装置10は、一部に専用のハードウェア回路を備える構成であってもよい。
求解装置10は、メモリ204と、1または複数のハードウェアプロセッサ206と、記憶装置208と、操作装置210と、表示装置212と、通信装置214とを備える。各部は、バスにより接続される。
メモリ204は、例えば、ROM222と、RAM224とを含む。ROM222は、求解装置10の制御に用いられるプログラムおよび各種設定情報等を書き換え不可能に記憶する。RAM224は、SDRAM(Synchronous Dynamic Random Access Memory)等の揮発性の記憶媒体である。RAM224は、1または複数のハードウェアプロセッサ206の作業領域として機能する。
1または複数のハードウェアプロセッサ206は、メモリ204(ROM222およびRAM224)にバスを介して接続される。1または複数のハードウェアプロセッサ206のそれぞれは、例えば、CPU(Central Processing Unit)であってもよいし、演算用のハードウェア回路であってもよい。
1または複数のハードウェアプロセッサ206は、RAM224の所定領域を作業領域としてROM222または記憶装置208に予め記憶された各種プログラムとの協働により各種処理を実行し、求解装置10を構成する各部の動作を統括的に制御する。また、1または複数のハードウェアプロセッサ206は、ROM222または記憶装置208に予め記憶されたプログラムとの協働により、操作装置210、表示装置212および通信装置214等を制御する。
記憶装置208は、フラッシュメモリ等の半導体による記憶媒体、磁気的または光学的に記録可能な記憶媒体等の書き換え可能な記録装置である。記憶装置208は、求解装置10の制御に用いられるプログラムおよび各種設定情報等を記憶する。
操作装置210は、マウスおよびキーボード等の入力デバイスである。操作装置210は、ユーザから操作入力された情報を受け付け、受け付けた情報を1または複数のハードウェアプロセッサ206に出力する。
表示装置212は、情報をユーザに表示する。表示装置212は、1または複数のハードウェアプロセッサ206から情報等を受け取り、受け取った情報を表示する。なお、通信装置214または記憶装置208等に情報を出力する場合、求解装置10は、表示装置212を備えなくてもよい。通信装置214は、外部の機器と通信して、ネットワーク等を介して情報を送受信する。
本実施形態の求解装置10で実行されるプログラムは、インストール可能な形式または実行可能な形式のファイルでCD-ROM、フレキシブルディスク(FD)、CD-R、DVD(Digital Versatile Disk)等のコンピュータで読み取り可能な記録媒体に記録されて提供される。
また、本実施形態の求解装置10で実行されるプログラムを、インターネット等のネットワークに接続されたコンピュータ上に格納し、ネットワーク経由でダウンロードさせることにより提供するように構成してもよい。また、本実施形態の求解装置10で実行されるプログラムをインターネット等のネットワーク経由で提供または配布するように構成してもよい。また、本実施形態の求解装置10で実行されるプログラムを、ROM等に予め組み込んで提供するように構成してもよい。
情報処理装置を求解装置10として機能させるためのプログラムは、例えば、取得モジュール、関数生成モジュール、更新モジュールおよび出力モジュールを含むモジュール構成となっている。さらに、プログラムは、第1ソルバーモジュールおよび第2ソルバーモジュールを含んでもよい。このプログラムは、1または複数のハードウェアプロセッサ206により実行されることにより各モジュールがメモリ204のRAM224にロードされ、1または複数のハードウェアプロセッサ206を、取得部22、関数生成部24、更新部30および出力部34として機能させる。さらに、このプログラムは、1または複数のハードウェアプロセッサ206を、第1ソルバー26および第2ソルバー42として機能させてもよい。なお、これらの構成は、一部または全部がハードウェアにより構成されていてもよい。
本発明のいくつかの実施形態を説明したが、これらの実施形態は、例として提示したものであり、発明の範囲を限定することは意図していない。これら新規な実施形態は、その他の様々な形態で実施されることが可能であり、発明の要旨を逸脱しない範囲で、種々の省略、置き換え、変更を行うことができる。これら実施形態やその変形は、発明の範囲や要旨に含まれるとともに、請求の範囲に記載された発明とその均等の範囲に含まれる。
10 求解装置、
22 取得部
24 関数生成部
26 第1ソルバー
30 更新部
32 更新値記憶部
34 出力部
42 第2ソルバー

Claims (19)

  1. それぞれが0または1となるI個(Iは2以上の整数)の決定変数を含む非凸二次関数である目的関数を最小化する問題の解を、それぞれが前記I個の決定変数のうちの少なくとも1つを変数として含むJ個(Jは0以上の整数)の連立一次方程式を満たし且つそれぞれが前記I個の決定変数のうちの少なくとも1つを変数として含むK個(Kは1以上の整数)の連立一次不等式を満たす条件の下で、算出する求解装置であって、
    前記目的関数、前記J個の連立一次方程式および前記K個の連立一次不等式を取得する取得部と、
    拡張ラグランジュ関数に基づき生成される前記I個の決定変数を含む第1関数を最小化する前記I個の決定変数の解の候補値を取得する第1処理、前記拡張ラグランジュ関数に基づき生成されるK個の従属変数を含む第2関数を最小化する前記K個の従属変数の解の候補値を取得する第2処理、および、前記拡張ラグランジュ関数に含まれる係数を更新する係数処理、を予め定められた順序で繰り返す更新部と、
    前記第1処理、前記第2処理および前記係数処理を繰り返すことによって予め設定された終了条件に達した場合、前記I個の決定変数の解の候補値を、前記問題の解として出力する出力部と、
    を備え、
    前記拡張ラグランジュ関数は、前記目的関数を含む目的関数項と、前記J個の連立一次方程式に対応するJ個の第1ラグランジュ項と、前記K個の連立一次不等式に対応するK個の第2ラグランジュ項と、ペナルティ項と、を含む
    求解装置。
  2. 前記J個の第1ラグランジュ項のそれぞれは、前記J個の連立一次方程式のうちの対応する連立一次方程式と前記I個の決定変数の解の候補値との誤差を表す関数に、J個の第1ラグランジュ係数のうちの対応する第1ラグランジュ係数を乗じた関数であり、
    前記K個の第2ラグランジュ項のそれぞれは、前記K個の連立一次不等式のうちの対応する連立一次不等式の不等号を等号に置き換え且つ定数項を前記K個の従属変数のうちの対応する従属変数に置き換えた代替方程式と、前記I個の決定変数の解の候補値との誤差を表す関数に、K個の第2ラグランジュ係数のうちの対応する第2ラグランジュ係数を乗じた関数であり、
    前記ペナルティ項は、それぞれが対応する連立一次方程式と前記I個の決定変数の解の候補値との距離を表すJ個の第1距離関数と、それぞれが対応する代替方程式と前記I個の決定変数の解の候補値との距離を表すK個の第2距離関数との合計に、ペナルティ係数を乗じた関数である
    請求項1に記載の求解装置。
  3. 前記更新部は、前記第2処理において、K個の不等式を満たす条件の下で、前記第2関数における前記K個の従属変数の解の候補値を取得し、
    前記K個の不等式のそれぞれは、前記K個の従属変数のうちの対応する従属変数が、前記K個の連立一次不等式のうちの対応する連立一次不等式における定数項以下であること表す
    請求項2に記載の求解装置。
  4. 前記第1関数は、前記拡張ラグランジュ関数に、前記K個の従属変数の解の候補値を代入した関数であり、
    前記第2関数は、前記拡張ラグランジュ関数に、前記I個の決定変数の解の候補値を代入した関数である
    請求項3に記載の求解装置。
  5. 前記更新部は、前記係数処理において、前記拡張ラグランジュ関数に含まれる係数として、前記J個の第1ラグランジュ係数、前記K個の第2ラグランジュ係数および前記ペナルティ係数を更新する
    請求項4に記載の求解装置。
  6. 前記ペナルティ係数は、正であり、
    前記更新部は、前記係数処理において、
    前記J個の第1ラグランジュ係数のそれぞれから、対応する連立一次方程式と前記I個の決定変数の解の候補値との誤差に応じた値を減じ、
    前記K個の第2ラグランジュ係数のそれぞれから、対応する代替方程式と前記I個の決定変数の解の候補値との誤差に応じた値を減じ、
    前記ペナルティ係数を増加させる
    請求項5に記載の求解装置。
  7. 前記更新部は、最初の前記第1処理、前記第2処理および前記係数処理に先だって、前記K個の従属変数の解の候補値のそれぞれ、前記J個の第1ラグランジュ係数のそれぞれ、前記K個の第2ラグランジュ係数のそれぞれ、および、前記ペナルティ係数に予め定められた初期値を代入する
    請求項6に記載の求解装置。
  8. 前記更新部は、前記第1処理において、前記第1関数を最小化する問題を0-1整数非凸二次計画問題の解を算出する第1ソルバーに与えて、前記第1ソルバーから前記I個の決定変数の解の候補値を取得する
    請求項1から7の何れか1項に記載の求解装置。
  9. 前記第1ソルバーが、複数組の前記I個の決定変数の解の候補値を出力する場合、前記更新部は、前記複数組の前記I個の決定変数の解の候補値に基づき、一組の前記I個の決定変数の解の候補値を更新する
    請求項8に記載の求解装置。
  10. 前記拡張ラグランジュ関数は、式(1)により表され、
    前記K個の不等式は、式(2)により表され、
    Figure 2022142914000044
    Figure 2022142914000045
    前記式(1)および前記式(2)において、
    iは、1以上、I以下の整数であり、前記I個の決定変数のそれぞれに割り当てられるインデックスを表し、
    i´は、1以上、I以下の整数であり、iとは異なり、前記I個の決定変数のそれぞれに割り当てられるインデックスを表し、
    は、前記I個の決定変数のうちのi番目の決定変数であり、
    i´は、前記I個の決定変数のうちのi´番目の決定変数であり、
    i,i´は、前記目的関数における2次項における前記i番目の決定変数と前記i´番目の決定変数との乗算値に乗算される係数であり、
    は、前記目的関数の1次項における前記i番目の前記決定変数に乗算される係数であり、
    jは、1以上、J以下の整数であり、前記J個の連立一次方程式のそれぞれに割り当てられるインデックスを表し、
    j,iは、前記J個の連立一次方程式のうちのj番目の連立一次方程式における前記i番目の決定変数に乗算される係数であり、
    は、前記j番目の連立一次方程式における定数項であり、
    kは、1以上、K以下の整数であり、前記K個の連立一次不等式のそれぞれに割り当てられるインデックスを表し、
    k,iは、前記K個の連立一次不等式のうちのk番目の連立一次不等式における前記i番目の決定変数に乗算される係数であり、
    は、前記k番目の連立一次不等式における定数項であり、
    は、k番目の代替方程式における従属変数であり、
    λは、前記J個の第1ラグランジュ係数のうちのj番目の第1ラグランジュ係数であり、
    λ´は、前記K個の第2ラグランジュ係数のうちのk番目の第2ラグランジュ係数であり、
    μは、前記ペナルティ係数である
    請求項4から7の何れか1項に記載の求解装置。
  11. それぞれが0または1となるI個(Iは2以上の整数)の第1決定変数を含む非凸二次関数と、それぞれが実数となるM個(Mは2以上の整数)の第2決定変数を含む連続凸関数とを加算した関数である目的関数を最小化する問題の解を、それぞれが前記I個の第1決定変数および前記M個の第2決定変数のうちの少なくとも1つを変数として含むJ個(Jは0以上の整数)の連立一次方程式を満たし、且つ、それぞれが前記I個の第1決定変数および前記M個の第2決定変数のうちの少なくとも1つを変数として含むK個(Kは1以上の整数)の連立一次不等式を満たす条件の下で、算出する求解装置であって、
    前記目的関数、前記J個の連立一次方程式および前記K個の連立一次不等式を取得する取得部と、
    拡張ラグランジュ関数に基づき生成される前記I個の第1決定変数を含む第1関数を最小化する前記I個の第1決定変数の解の候補値を取得する第1処理、前記拡張ラグランジュ関数に基づき生成される前記M個の第2決定変数およびK個の従属変数を含む第2関数を最小化する前記M個の第2決定変数および前記K個の従属変数の解の候補値を取得する第2処理、および、前記拡張ラグランジュ関数に含まれる係数を更新する係数処理、を予め定められた順序で繰り返す更新部と、
    前記第1処理、前記第2処理および前記係数処理を繰り返すことによって予め設定された終了条件に達した場合、前記I個の第1決定変数の解の候補値を、前記問題の解として出力する出力部と、
    を備え、
    前記拡張ラグランジュ関数は、前記目的関数を含む目的関数項と、前記J個の連立一次方程式に対応するJ個の第1ラグランジュ項と、前記K個の連立一次不等式に対応するK個の第2ラグランジュ項と、ペナルティ項と、を含む
    求解装置。
  12. 前記J個の第1ラグランジュ項のそれぞれは、前記J個の連立一次方程式のうちの対応する連立一次方程式と前記I個の第1決定変数および前記M個の第2決定変数の解の候補値との誤差を表す関数に、J個の第1ラグランジュ係数のうちの対応する第1ラグランジュ係数を乗じた関数であり、
    前記K個の第2ラグランジュ項のそれぞれは、前記K個の連立一次不等式のうちの対応する連立一次不等式の不等号を等号に置き換え且つ定数項を前記K個の従属変数のうちの対応する従属変数に置き換えた代替方程式と、前記I個の第1決定変数および前記M個の第2決定変数の解の候補値との誤差を表す関数に、K個の第2ラグランジュ係数のうちの対応する第2ラグランジュ係数を乗じた関数であり、
    前記ペナルティ項は、それぞれが対応する連立一次方程式と前記I個の第1決定変数および前記M個の第2決定変数の解の候補値との距離を表すJ個の第1距離関数と、それぞれが対応する代替方程式と前記I個の第1決定変数および前記M個の第2決定変数の解の候補値との距離を表すK個の第2距離関数との合計に、ペナルティ係数を乗じた関数である
    請求項11に記載の求解装置。
  13. 前記更新部は、前記第2処理において、K個の不等式を満たす条件の下で、前記第2関数における前記M個の第2決定変数および前記K個の従属変数の解の候補値を取得し、
    前記K個の不等式のそれぞれは、前記K個の従属変数のうちの対応する従属変数が、前記K個の連立一次不等式のうちの対応する連立一次不等式における定数項以下であることを表す
    請求項12に記載の求解装置。
  14. 前記第1関数は、前記拡張ラグランジュ関数に、直前の前記第2処理において算出された前記K個の従属変数および前記M個の第2決定変数の解の候補値を代入した関数であり、
    前記第2関数は、前記拡張ラグランジュ関数に、直前の前記第1処理において算出された前記I個の第1決定変数の解の候補値を代入した関数である
    請求項13に記載の求解装置。
  15. 前記更新部は、前記第2処理において、凸二次計画問題の解を算出する第2ソルバーに前記第2関数および前記K個の不等式を与えて、前記第2ソルバーから前記第2関数における前記M個の第2決定変数および前記K個の従属変数の解の候補値を取得する
    請求項14に記載の求解装置。
  16. 前記拡張ラグランジュ関数は、式(3)により表され、
    前記K個の不等式は、式(4)により表され、
    Figure 2022142914000046
    Figure 2022142914000047
    前記式(3)および前記式(4)において、
    iは、1以上、I以下の整数であり、前記I個の第1決定変数のそれぞれに割り当てられるインデックスを表し、
    i´は、1以上、I以下の整数であり、iとは異なり、前記I個の第1決定変数のそれぞれに割り当てられるインデックスを表し、
    は、前記I個の第1決定変数のうちのi番目の第1決定変数であり、
    i´は、前記I個の第1決定変数のうちのi´番目の第1決定変数であり、
    i,i´は、前記目的関数の2次項における前記i番目の第1決定変数と前記i´番目の第1決定変数との乗算値に乗算される係数であり、
    は、前記目的関数の1次項における前記i番目の第1決定変数に乗算される係数であり、
    R(y)は、前記連続凸関数であり、
    は、前記M個の第2決定変数のうちのm番目の第2決定変数であり、
    jは、1以上、J以下の整数であり、前記J個の連立一次方程式のそれぞれに割り当てられるインデックスを表し、
    j,iは、前記J個の連立一次方程式のうちのj番目の連立一次方程式におけるi番目の前記第1決定変数に乗算される係数であり、
    j,mは、前記j番目の連立一次方程式における前記m番目の第2決定変数に乗算される係数であり、
    は、前記j番目の連立一次方程式における定数項であり、
    kは、1以上、K以下の整数であり、前記K個の連立一次不等式のそれぞれに割り当てられるインデックスを表し、
    k,iは、前記K個の連立一次不等式のうちのk番目の連立一次不等式におけるi番目の前記第1決定変数に乗算される係数であり、
    k,iは、前記k番目の連立一次不等式における前記m番目の第2決定変数に乗算される係数であり、
    は、前記k番目の連立一次不等式における定数項であり、
    は、k番目の代替方程式における従属変数であり、
    λは、前記J個の第1ラグランジュ係数のうちのj番目の第1ラグランジュ係数であり、
    λ´は、前記K個の第2ラグランジュ係数のうちのk番目の第2ラグランジュ係数であり、
    μは、前記ペナルティ係数である
    請求項14または15に記載の求解装置。
  17. 前記連続凸関数は、連続凸二次関数である
    請求項11から16の何れか1項に記載の求解装置。
  18. 情報処理装置を求解装置として機能させるためのプログラムであって、
    前記求解装置は、それぞれが0または1となるI個(Iは2以上の整数)の決定変数を含む非凸二次関数である目的関数を最小化する問題の解を、それぞれが前記I個の決定変数のうちの少なくとも1つを変数として含むJ個(Jは0以上の整数)の連立一次方程式を満たし且つそれぞれが前記I個の決定変数のうちの少なくとも1つを変数として含むK個(Kは1以上の整数)の連立一次不等式を満たす条件の下で、算出し、
    前記情報処理装置を、
    前記目的関数、前記J個の連立一次方程式および前記K個の連立一次不等式を取得する取得部と、
    拡張ラグランジュ関数に基づき生成される前記I個の決定変数を含む第1関数を最小化する前記I個の決定変数の解の候補値を取得する第1処理、前記拡張ラグランジュ関数に基づき生成されるK個の従属変数を含む第2関数を最小化する前記K個の従属変数の解の候補値を取得する第2処理、および、前記拡張ラグランジュ関数に含まれる係数を更新する係数処理、を予め定められた順序で繰り返す更新部と、
    前記第1処理、前記第2処理および前記係数処理を繰り返すことによって予め設定された終了条件に達した場合、前記I個の決定変数の解の候補値を、前記問題の解として出力する出力部と、
    して機能させ、
    前記拡張ラグランジュ関数は、前記目的関数を含む目的関数項と、前記J個の連立一次方程式に対応するJ個の第1ラグランジュ項と、前記K個の連立一次不等式に対応するK個の第2ラグランジュ項と、ペナルティ項と、を含む
    プログラム。
  19. 情報処理装置を求解装置として機能させるためのプログラムであって、
    前記求解装置は、それぞれが0または1となるI個(Iは2以上の整数)の第1決定変数を含む非凸二次関数と、それぞれが実数となるM個(Mは2以上の整数)の第2決定変数を含む連続凸関数とを加算した関数である目的関数を最小化する問題の解を、それぞれが前記I個の第1決定変数および前記M個の第2決定変数のうちの少なくとも1つを変数として含むJ個(Jは0以上の整数)の連立一次方程式を満たし、且つ、それぞれが前記I個の第1決定変数および前記M個の第2決定変数のうちの少なくとも1つを変数として含むK個(Kは1以上の整数)の連立一次不等式を満たす条件の下で、算出し、
    前記情報処理装置を、
    前記目的関数、前記J個の連立一次方程式および前記K個の連立一次不等式を取得する取得部と、
    拡張ラグランジュ関数に基づき生成される前記I個の第1決定変数を含む第1関数を最小化する前記I個の第1決定変数の解の候補値を取得する第1処理、前記拡張ラグランジュ関数に基づき生成される前記M個の第2決定変数およびK個の従属変数を含む第2関数を最小化する前記M個の第2決定変数および前記K個の従属変数の解の候補値を取得する第2処理、および、前記拡張ラグランジュ関数に含まれる係数を更新する係数処理、を予め定められた順序で繰り返す更新部と、
    前記第1処理、前記第2処理および前記係数処理を繰り返すことによって予め設定された終了条件に達した場合、前記I個の第1決定変数の解の候補値を、前記問題の解として出力する出力部と、
    して機能させ、
    前記拡張ラグランジュ関数は、前記目的関数を含む目的関数項と、前記J個の連立一次方程式に対応するJ個の第1ラグランジュ項と、前記K個の連立一次不等式に対応するK個の第2ラグランジュ項と、ペナルティ項と、を含む
    プログラム。
JP2021043184A 2021-03-17 2021-03-17 求解装置およびプログラム Active JP7455773B2 (ja)

Priority Applications (4)

Application Number Priority Date Filing Date Title
JP2021043184A JP7455773B2 (ja) 2021-03-17 2021-03-17 求解装置およびプログラム
CA3212411A CA3212411A1 (en) 2021-03-17 2022-03-16 Solver apparatus and program
PCT/JP2022/012072 WO2022196739A1 (ja) 2021-03-17 2022-03-16 求解装置およびプログラム
US18/466,878 US20230418895A1 (en) 2021-03-17 2023-09-14 Solver apparatus and computer program product

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2021043184A JP7455773B2 (ja) 2021-03-17 2021-03-17 求解装置およびプログラム

Publications (2)

Publication Number Publication Date
JP2022142914A true JP2022142914A (ja) 2022-10-03
JP7455773B2 JP7455773B2 (ja) 2024-03-26

Family

ID=83321087

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2021043184A Active JP7455773B2 (ja) 2021-03-17 2021-03-17 求解装置およびプログラム

Country Status (4)

Country Link
US (1) US20230418895A1 (ja)
JP (1) JP7455773B2 (ja)
CA (1) CA3212411A1 (ja)
WO (1) WO2022196739A1 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11765937B2 (en) 2017-12-19 2023-09-19 Lg Display Co., Ltd. Display device

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10579702B2 (en) * 2018-04-19 2020-03-03 City University Of Hong Kong Systems and methods for signal processing using coordinate descent techniques for unit modulus least squares (UMLS) and unit-modulus quadratic program (UMQP)
WO2020196862A1 (ja) 2019-03-28 2020-10-01 株式会社 東芝 情報処理装置、情報処理システム、情報処理方法、記憶媒体およびプログラム
CN112072668B (zh) 2020-08-31 2022-07-26 华南理工大学 一种电力系统凸分布式最优潮流求解方法

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11765937B2 (en) 2017-12-19 2023-09-19 Lg Display Co., Ltd. Display device

Also Published As

Publication number Publication date
CA3212411A1 (en) 2022-09-22
JP7455773B2 (ja) 2024-03-26
US20230418895A1 (en) 2023-12-28
WO2022196739A1 (ja) 2022-09-22

Similar Documents

Publication Publication Date Title
US11250308B2 (en) Apparatus and method for generating prediction model based on artificial neural network
KR20160143505A (ko) 신경망의 연산량을 줄이는 방법 및 시스템
Bistrian et al. Processing epidemiological data using dynamic mode decomposition method
WO2018144534A1 (en) Hardware-based machine learning acceleration
US11520560B2 (en) Computer processing and outcome prediction systems and methods
WO2022196739A1 (ja) 求解装置およびプログラム
JP2017049907A (ja) ニューラルネットワーク、その学習方法、及びコンピュータプログラム
JP2014160457A (ja) 対話的変数選択装置、対話的変数選択方法および対話的変数選択プログラム
Roland et al. The inverse {0, 1}-knapsack problem: theory, algorithms and computational experiments
Akcin et al. Performance of artificial neural networks on kriging method in modeling local geoid
US11526690B2 (en) Learning device, learning method, and computer program product
Iquebal et al. Emulating the evolution of phase separating microstructures using low-dimensional tensor decomposition and nonlinear regression
Hoang et al. On the design of a stable adaptive filter for state estimation in high dimensional systems
JP5300556B2 (ja) 目標追尾装置
Amador et al. Parameter estimation of the kinetic α-pinene isomerization model using the mcsfilter algorithm
JP6660248B2 (ja) 目的変数予測装置、方法及びプログラム
Wani et al. An improved particle swarm optimisation-based functional link artificial neural network model for software cost estimation
JP2019075003A (ja) 近似計算装置、近似計算方法及びプログラム
Agulhari et al. Reduced order dynamic controller synthesis conditions for LPV periodic discrete-time systems subject to input saturation
Kolpakov et al. Estimating the computational complexity of one variant of parallel realization of the branch-and-bound method for the knapsack problem
JP7147874B2 (ja) 学習装置、学習方法および学習プログラム
Ossorio-Castillo et al. Quantum algorithms for the Sylvester denumerant and the numerical semigroup membership problem
CN112930542A (zh) 用于量化神经网络的系统和方法
Khoo et al. Celestial Machine Learning: From Data to Mars and Beyond with AI Feynman
WO2022137520A1 (ja) 学習装置、学習方法および学習プログラム

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20230330

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20240213

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20240313

R150 Certificate of patent or registration of utility model

Ref document number: 7455773

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150