半正定値計画法とは? わかりやすく解説

Weblio 辞書 > 辞書・百科事典 > 百科事典 > 半正定値計画法の意味・解説 

半正定値計画問題

(半正定値計画法 から転送)

出典: フリー百科事典『ウィキペディア(Wikipedia)』 (2025/05/17 02:51 UTC 版)

半正定値計画問題(はんせいていちけいかくもんだい、: semidefinite programming)とは、半正定値行列全体によって作られる凸錐体上での凸最適化問題(convex optimization)の一つである。

半正定値計画問題は近年いくつかの理由で成長している最適化の一分野である。その理由として多くの実用例が考えられることがあげられるが、特にオペレーションズ・リサーチ組み合わせ最適化などの分野で広く研究が行われている。自動制御理論の分野では半正定値計画問題が線形不等式制約のもとで行われることが多い。半正定値計画問題は、凸錐体上の凸最適化問題の一種であり、内点法などにより効率よく解を与えることが可能であることも、応用が期待される一要因となっている[1]。また半正定値計画問題の階層化により多項式最適化問題が近似的に解けるほか、複雑系の最適化にも応用が可能である。

定義

線形計画問題はある空間上で多面体に含まれるような実数の組に対して、線形の目的関数を最小化・最大化する問題である。ここで、多面体というのは、より厳密には凸集合であるということを指す。一方で、半正定値計画問題においては、ベクトルの内積を最適化する。特に、一般的な半正定値計画問題は、数理計画問題の形式として、以下のように定義される(ただし、内積を表す)。

さらに、この問題は半正定値行列の作る凸錐体上の問題として書き直すことができる。大きさが の行列 本のベクトル を用いて で表されるとき、行列グラム行列といい、この行列は半正定値となることが知られている。

ここで、 を実対称行列全体の空間とする。この空間では内積を (ただし、 は行列のを表す)と定義することができて、これを用いると、前述のベクトルを用いた半正定値計画問題が次の形で書き直せる。

ただし、 とは行列 が半正定値行列であることを表す。この式において を、 の行列で を成分に持つ。

双対性

双対問題の定義

線形計画問題と同様、半正定値計画問題も双対問題を考えることが可能で、

という半正定値計画問題の双対問題は

という形で与えられる。なお大きさが等しい2つの正方行列 に対して、 とは、 と同義である。

弱双対性

弱双対定理とは、半正定値計画問題の主問題と双対問題の許容解の関係を表す定理であり、主問題の許容解が双対問題の上界となり、双対問題の許容解が主問題の下界となるというものである。 これは、次の式により示される。

最後の不等式が成立するのは、行列の内積を取っている2つの行列が、どちらも半正定値行列であるためである。

強双対性

スレーター条件と呼ばれる条件の下では、主問題と双対問題の最適解が一致することが知られている。これを強双対性という。線形計画問題と違い、半正定値問題は、すべての問題が強双対性を満たすわけではなく、一般には双対問題の最適解は主問題の最適解よりも小さい。強双対性は次の2つの性質により言い表される。

  1. 主問題が下に有界であり、かつ内点許容解をもつとき、双対問題が最適解を持つ。
  2. 双対問題が上に有界であり、かつ内点許容解をもつとき、主問題が最適解を持つ。

この2つの性質から、主問題と双対問題の両方が最適解を持ち、それらが一致することが言える。

脚注

  1. ^ 藤江 2012, p. 832.

参考文献




英和和英テキスト翻訳>> Weblio翻訳
英語⇒日本語日本語⇒英語
  

辞書ショートカット

すべての辞書の索引

「半正定値計画法」の関連用語

半正定値計画法のお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



半正定値計画法のページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
ウィキペディアウィキペディア
All text is available under the terms of the GNU Free Documentation License.
この記事は、ウィキペディアの半正定値計画問題 (改訂履歴)の記事を複製、再配布したものにあたり、GNU Free Documentation Licenseというライセンスの下で提供されています。 Weblio辞書に掲載されているウィキペディアの記事も、全てGNU Free Documentation Licenseの元に提供されております。

©2025 GRAS Group, Inc.RSS