|
分枝限定法(ぶんしげんていほう、)は、各種最適化問題(特に離散最適化と組合せ最適化)の最適解を求める汎用アルゴリズムである。分枝操作()と限定操作()から構成される。全ての解候補を体系的に列挙するもので、最適化された量の上限と下限の概算を使って、最適でない候補は「ひとまとめに」捨てられる。 1960年、A. H. Land と A. G. Doig が線型計画法の手法として最初に提案した。 == 概要 == 関数 の最小値を求める最適化問題を考える。 とする。 分枝限定法には2つの手続きが必要である。 ; 分枝 : 第一は分枝操作である。場合分けにより部分問題に分割する。つまり、与えられた集合 に対して、 となるような複数の集合 に分割(分枝)する手続きである。 における の最小値を としたとき、 における の最小値は である。この手続きを再帰的に適用することは分枝法 (branching) と呼ばれ、各ノードが の部分集合となるような木(探索木)になる。なお でも良い。 ; 限定 : 第二の手続きは、 の1つの部分集合 の の最小値の上限と下限を計算する手続きである。これを限定法 (bounding) と呼ぶ。 : 分枝限定法の鍵となるのは、あるノード(候補集合) の下限が別のノード の上限より大きければ、A は探索するまでもなく捨ててよいという考え方である。この工程を刈り込み (pruning) と呼び、一般に大域変数 にそれまでに調べた部分の最小の上限値を保持するような実装で実現する。下限が より大きいノードは捨てることができる。 : 再帰は候補集合 が1つの元になった時点で停止するか、 の上限が下限と一致した場合に停止する。どちらにしても、停止したときの のどの元も関数を最小値にする。 分枝限定法は、限定法の種類によって分類したり、探索木のノードの生成/検査方法で分類したりする。 分枝限定法の設計戦略は、状態空間木を問題を解くのに使うという点でバックトラッキングとよく似ている。これらの違いは、分枝限定法が木の走査順序を限定していないという点と、分枝限定法が最適化問題でしか使われないという点である。 動的計画法や貪欲法は部分問題の最適性が必要であるが、成立しない部分問題に対して、適切に場合分けして分枝することにより、分枝限定法でうまく行くこともある。 分枝が場合分けをするので並列実装や分散実装に適している。 抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)』 ■ウィキペディアで「分枝限定法」の詳細全文を読む スポンサード リンク
|