|
カーマーカーのアルゴリズム () とは1984年、ナレンドラ・カーマーカーにより発見された線形計画問題の解法である。このアルゴリズムは、しばしば、カーマーカー法 (Karmarkar's method) とも呼ばれる。また、このアルゴリズムを発明とする特許が米国や日本で出願されたので、請求特許は時折カーマーカー特許 (Karmarkar's patent) とも呼称される。 カーマーカーのアルゴリズムは、線形計画問題における適度に効率が良い多項式時間アルゴリズムとしては初のものである。も多項式時間アルゴリズムであるが、実際の効率は良くない。 カーマーカーのアルゴリズムは内点法の一種である。内点法は単体法とは異なり、想定解が実行可能集合〔 "feasible set"。または"feasible region"(「実行可能領域」)とも呼ばれる。"feasible"は「許容」、「制約」などとも訳される。を参照。 〕の境界には存在せず、実行可能集合の内部を通って最適解(optimal solution)に漸近する。それだけではなく、このアルゴリズムは、以前のアルゴリズムに比べ、有限小数を繰り返し利用することによる最適解への漸近処理を改善しており、かつ、有意なデータでもって最適解へ収束させる〔 〕。 == アルゴリズム == 行列 、ベクトル に対し、以下のな線形計画問題を考える。 : maximize ''c''''T''''x'' : subject to ''Ax'' ≤ ''b''. すなわち、 : 条件 ''Ax'' ≤ ''b'' の下で、 : ''c''''T''''x'' を最大にするベクトル ''x'' を求める。 このアルゴリズムはその時点での最適化実行可能方向 (feasible direction toward optimality) を決定し、因子γは 0 < γ ≤ 1 の範囲でスケールバックする。 カーマーカーのアルゴリズムは複雑である。アフィン・スケーリング法と呼ばれる簡略化されたバージョンが、カーマーカーとは別の人物により提案、解析されている〔 〕。このアルゴリズムは以下のように簡潔に示される。ただし、アフィン・スケーリング・アルゴリズムは実用上効率が良いが、多項式時間アルゴリズムではない。 Input: A, b, c, , ''stopping criterion''〔停止条件。アルゴリズムのとおり、while文は停止条件を満たすとループを抜ける。〕, . do while ''stopping criterion'' not satisfied 〔行列の対角成分を代入。〕 if then〔条件を満たす場合は、戻り値"unbounded"を返す。〕 return unbounded end if end do 抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)』 ■ウィキペディアで「カーマーカーのアルゴリズム」の詳細全文を読む 英語版ウィキペディアに対照対訳語「 Karmarkar's algorithm 」があります。 スポンサード リンク
|