カーマーカーのアルゴリズム

提供: testwiki
ナビゲーションに移動 検索に移動

カーマーカーのアルゴリズムテンプレート:Lang-en-short)とは1984年ナレンドラ・カーマーカーにより発見された線形計画問題の解法である。このアルゴリズムは、しばしば、カーマーカー法: Karmarkar's method)とも呼ばれる。また、このアルゴリズムを発明とする特許米国日本で出願され、請求特許は時折カーマーカー特許 (Karmarkar's patent) とも呼称される。

カーマーカーのアルゴリズムは、線形計画問題に対する多項式時間アルゴリズムで初めての実用的なものである。楕円体法も多項式時間アルゴリズムであるが、実用上の効率は良くない。

カーマーカーのアルゴリズムは内点法の一種である。内点法は、候補解を実行可能領域境界に沿って更新する単体法とは異なり、実行可能領域の内部を通るよう更新する。この更新は解の精度を定数倍改善し、これを繰り返すことで最適解optimal solution)に収束する[1]

アルゴリズム

行列 Aベクトル b に対し、以下のテンプレート:仮リンク線形計画問題を考える。

maximize cTx
subject to Axb.

すなわち、

条件 Axb の下で、
cTx を最大にするベクトル x を求める。

このアルゴリズムはその時点での最適化実行可能方向 (feasible direction toward optimality) を求め、0 < γ ≤ 1 の範囲で縮小する。

カーマーカーのアルゴリズムは複雑である。アフィン・スケーリング法と呼ばれる簡略化されたバージョンが、カーマーカーとは別の人物により提案、解析されている[2]。このアルゴリズムは以下のように簡潔に示される。ただし、アフィン・スケーリング・アルゴリズムは実用上効率が良いが、多項式時間アルゴリズムではない。

テンプレート:Algorithm-begin

  Input:  A, b, c, x0, stopping criterion[注釈 1], γ.
  k0
  do while stopping criterion not satisfied
     vkbAxk
     Dvdiag(v1k,,vmk)[注釈 2]
     hx(ATDv2A)1c
     hvAhx
     if hv0 then[注釈 3]
        return unbounded
     end if
     αγmin{vik/(hv)i|(hv)i<0,i=1,,m}
     xk+1xk+αhx
     kk+1
  end do

テンプレート:Algorithm-end

例題

例解

以下の線形計画問題を考える。

maximize x1+x2
subject to 2px1+x2p2+1,p=0.0,0.1,0.2,,0.9,1.0.

上記には、2つの変数 x1,x2 と、11の束縛変数 p がある。本節の例解図には、アルゴリズムを繰り返し実行するごとに赤い円が点描されることと、青い直線は束縛境界であることが示されている。

計算量

n変数の個数、L をアルゴリズムの入力ビット数としたとき、カーマーカーのアルゴリズムは、桁数のオーダー O(L) に対し、操作数 (operations) のオーダー O(n3.5L) をもつ。比較として、楕円体法の操作数は O(n6L) のオーダーをもつ。カーマーカーのアルゴリズムの実行時間(runtime、計算量)は、高速フーリエ変換に基づく乗算であるシェーンハーゲ・シュトラッセンのアルゴリズムで使用した場合、以下のオーダーをもつ。

O(n3.5L2logLloglogL)

(記号"O"についてはランダウの記号を参照のこと。)

特許論争

カーマーカーはAT&Tに採用されたのち、彼がこのアルゴリズムを発見してからは、彼と雇用者のAT&Tはこの発明が実用上重要なものとなる、ということを信じて疑わなかった。1985年4月になると、AT&Tは、カーマーカーのアルゴリズムを特許として出願し、ソフトウェア特許問題についての従来からの論争に対し火に油を注いだ[3]ロナルド・リベストをはじめとする多くの数学者がこの事態の進展を不安視し(しかし、皮肉なことにロナルドはRSA暗号アルゴリズムの特許権保持者の一人である)、アルゴリズムはフリーであるべきとの考えに沿って研究を進めるとの意見を彼らの多くが述べていた。実際に特許が既に許可されたとしても、適用可能なテンプレート:仮リンクが存在するとも考えられていた[4]フィリップ・ギル (Philip Gill) などをはじめとする数値解析を専攻する数学者たちは、適切な媒介変数を選択することで、カーマーカーのアルゴリズムが対数障壁関数射影ニュートン障壁法 (projected Newton barrier method) と同値であることを証明した[5]。ギルが提示した手法は1960年代から非線形計画法に広く利用されている。また事実として、1968年に初版が出版されたある著名な書籍には、線形計画問題の解法としてこの手法が明示されていた[6]。しかし、数名が次のように述べている。彼らが主張する手法が「アルゴリズム」としてさえも見なされない限り、ギルの証明に誤りがある。なぜなら、その手法は内部的なアルゴリズムからは導けない媒介変数を選択する必要があることを示しているが、それは外部の補助に依存、すなわち実質的にはカーマーカーのアルゴリズムから導かれるものだからである[7]。そのうえ、ザルツマン (Saltzman) が引用している、フィアッコ=マコーミック (Fiacco-McCormick)、ギル、その他の人物による全ての先行作業を考慮してみると、カーマーカーが与えた貢献は明快なものとは程遠いと考えられる[7][8][9]。この発明は1988年5月、テンプレート:US patent"Methods and apparatus for efficient resource allocation"(最適資源割当のための方法および装置)として結局許可された。このアルゴリズムは射影変換アフィン変換の組合せによる線形計画問題の解法であり[10]、米国の特許では双方のアルゴリズムそれぞれに特許が与えられている。日本では後者だけに特許が出願公告(当時)され、その後特許が認められた。

  • 特許第2033073号「最適資源割当方法」
  • 特願昭61-501865
  • 特公昭62-502580
  • 特公平5-61672

しかし、AT&Tにとってこの特許の商用的価値は限られたものになった。彼らはKORBX[注釈 4]というシステムを製造した[11]。このシステムは、アライアント製のプロセッサ8つを搭載し、カーマーカーのアルゴリズムを使用するソフトウェアを組み合わせて線形計画問題を解くという専用システムであり、1台890万ドルもの値段が付けられていた。しかし、売れたのは2台だけだった[4][注釈 5]。日本においては、1997年(平成9年)今野浩らにより本特許の無効審判請求がなされた(事件番号:平成9年審判第2452号事件)が、特許庁審判官は、「本件発明が、ハードウェア資源を用いて最適割当てのための演算処理を当該アルゴリズムを利用し結果を得るものであると認める。本件発明はアルゴリズムそのものではなく、また計算機を単に利用しただけのものでもない。」とし、原告の訴えを無効とする審決を下した[12]

テンプレート:See2

本審決後、原告は審決等取消訴訟を求め東京高等裁判所出訴した(事件番号:平成11年(行ケ)第25号 審決取消請求事件)。この訴えに対する判決[13]において、被告のルーセント・テクノロジー(カーマーカーが所属したAT&Tテクノロジーの承継企業)が2000年12月11日付けで特許庁に当該特許の放棄による特許権抹消の登録を行っていたことが明らかになった。以下判決文より引用すると、 テンプレート:Quote これによって原告の訴えの利益が消滅したので、本件は却下されている。結果として該当特許自身が「発明」の要件を満たしていたか(特許適格性)は判示されていない。

米国では、特許保護期間が2006年4月に満了し、本特許は現在では完全にパブリックドメイン下におかれている。

ソフトウェア特許に反対する者は、線形計画法の研究者と産業界とのつながりを以前から特徴付けている、両者の相互交流の正のサイクルを特許が駄目にしてしまうと強く主張している。そして、特許のせいで、他ならぬカーマーカー自身が線形計画法を共に研究する数学者の輪から孤立してしまった、と主張している[14]

脚注

参考文献

テンプレート:脚注ヘルプ

注釈

テンプレート:Reflist

出典

テンプレート:Reflist

関連項目

外部リンク

テンプレート:アルゴリズム テンプレート:最適化アルゴリズム テンプレート:Applied-math-stub テンプレート:Law-stub


引用エラー: 「注釈」という名前のグループの <ref> タグがありますが、対応する <references group="注釈"/> タグが見つかりません