240 likes | 443 Views
(1,6). 1. 4. (7,15). (7,15). (7,15). (4,4). (8,21). (10,13). (10,13). (10,13). (2,6). (5,2). (13,10). (13,10). (13,10). (15,16). (12,19). (15,16). (7, 15). (17,15). (1,6). (4,4). (19,11). (17,19). o. (9,7). (9,7). (9,7). 2. (13,11). (13,11). (13,11). (11,19). 5.
E N D
(1,6) 1 4 (7,15) (7,15) (7,15) (4,4) (8,21) (10,13) (10,13) (10,13) (2,6) (5,2) (13,10) (13,10) (13,10) (15,16) (12,19) (15,16) (7, 15) (17,15) (1,6) (4,4) (19,11) (17,19) o (9,7) (9,7) (9,7) 2 (13,11) (13,11) (13,11) (11,19) 5 d (9,4) (4,4) (5,2) (0,0) (0, 0) (16,8) (12,4) (1,6) (14,9) (14,9) (14,9) (4,4) (5,2) 3 (5,2) (12,17) (12,17) (12,17) 6 (12,4) (12,4) (12,4) (17,6) 制約付き最短路問題に対する実験的解析 上智大学 宮本裕一郎
(3時間,5千円) (3時間,3千円) 青森 函館 盛岡 (5時間,1万2千円) 東京 (3時間,2万5千円) 制約付き最短路問題のイメージ 制約付き 最短路問題のイメージ 各地点間の移動時間 がわかっている. 出発地から目的地までの経路のうち 移動時間最小の経路を見つけよ. ・移動費用 ただし,定められた予算上限を超えてはいけない. 予算上限が 2万円ならば 制約付き最短路 最短路 アルゴリズム研究会
数理計画問題(整数線形計画問題)としての定式化数理計画問題(整数線形計画問題)としての定式化 G=(V,E):有向グラフ (te,ce):枝eの(移動時間,移動費用) U:費用上限 o:出発地点 d:目的地点 線形緩和解が整数解になるとは限らない サブセットサムを帰着可能→(弱)NP-困難 ナップサック問題に類似 start(e):枝eの始点 end(e):枝eの終点 非負整数 アルゴリズム研究会
大規模な問題を解くためにメタ解法を開発 解近傍を計算する際に サブルーチンとして最短路問題 ネットワーク設計問題に制約がある場合には サブルーチンとして制約付き最短路問題 問題の背景 参考文献にはいろいろ応用があると書いてありますが・・・ システムの費用が枝ごとの費用の和になっている ネットワーク設計問題 アルゴリズム研究会
問題の種類 • 上限制約だけのもの • 下限制約があるもの • 制約が複数あるもの • ・・・ 既存の研究 • 解法 • 厳密アルゴリズム 擬多項式(Dijkstraベース,Bellman-Fordベース) 指数(分枝限定法,第k最短路への帰着) • 多項式時間近似アルゴリズム (目的関数に依存,解の数を多項式個に限定) • 発見的アルゴリズム (Lagrange緩和ベース,最も多い) 本研究の位置づけ 既存の擬多項式時間厳密アルゴリズムを改良 計算量を若干軽減,O(n2C(log n + C)) 実際の計算時間は? log C)) n:点数 C:入力定数 アルゴリズム研究会
Dijkstra法の簡単な説明 枝(v,w)があるとき, wへの最短路長≦vへの最短路長+枝長 という再帰方程式をもとに,出発点から近い順に最短路を確定 Dijkstra法 ステップ1:∀v∈V\o, Lv=∞Lo=0S=V ステップ2: S=空ならばアルゴリズム終了そうでないならばLv=min{Lv:v∈S}を満たすvを探す ステップ3: ∀(v,w) ∈E, Lw=min{Lw, Lv+枝長}, S=S\v, ステップ2に行く. アルゴリズム研究会
∞ 7 ∞ 8 1 1 4 2 4 5 7 ∞ 0 1 11 ∞ 9 ∞ 4 o 9 2 4 5 d 5 12 1 12 ∞ ∞ 12 4 5 3 5 6 Dijkstra法の簡単な例 7 7 8 8 10 10 0 0 9 9 アルゴリズム研究会
各点に (時間,費用)を表す ベクトル値のラベルを保持 各点に ラベルを複数保持 パレート解だけ保持 そのまま Dijkstra法の拡張 各点に (時間)距離を表す スカラー値のラベルを保持 各点に ラベルを1つ保持 出発地点から(時間距離で) 近いラベルから確定 アルゴリズム研究会
(∞, ∞) (∞, ∞) (1,6) 1 4 (4,4) (2,6) (5,2) (7, 15) (∞, ∞) (1,6) (∞, ∞) (∞, ∞) (4,4) o (9,4) 2 (4,4) 5 d (5,2) (0, 0) (12,4) (1,6) (∞, ∞) (∞, ∞) (4,4) (5,2) 3 (5,2) 6 (時間,費用) 費用上限=18 提案するアルゴリズムの簡単な例 (7,15) (7,15) (7,15) (10,13) (8,21) (10,13) (10,13) (13,10) (13,10) (13,10) (12,19) (15,16) (15,16) (17,15) (19,11) (17,19) (9,7) (9,7) (9,7) (13,11) (13,11) (13,11) (11,19) (0, 0) (0,0) (16,8) (14,9) (14,9) (14,9) (12,17) (12,17) (12,17) (12,4) (12,4) (12,4) (17,6) アルゴリズム研究会
アルゴリズムの概要 拡張Dijkstra法 ステップ1:∀v∈V\o, Lv={(∞, ∞)}Lo={(0,0)}S=空 ステップ2: {Uv∈VLv}\S=空ならばアルゴリズム終了(解なし)そうでないならばt*=min{t:(t,c)∈{Uv∈VLv}\S}を満たす(t*,c)を探す(t*,c) ∈Ldならば終了.(t*,c)が最適解そうでないならばステップ3へ ステップ3: (t*,c) ∈Lvとする。 ∀(v,w) ∈E, Lw=LwU{(t + te,c + ce)},Lwから実行不可能なもの,パレート解でないものを省く S=SU(t,c), ステップ2に行く. アルゴリズム研究会
確定したラベルよりも時間が大きいラベルのみ出現確定したラベルよりも時間が大きいラベルのみ出現 • いつかは最適解のラベルが出現 • 巡回なし 擬多項式回の確定で終了 アルゴリズムの正当性 • 確定していないラベルのうち時間が最小のものを選んで確定 • 後続する点のラベル集合を更新 • ラベルは1つずつ確定 • 各点で確定されるラベルの • 総数の上界はパレート解の数 枝重みが整数 ↓ 擬多項式個 アルゴリズム研究会
(14,9) (19,11) (17,6) (22,8) (14,9) (17,6) (19,11) 既存のアルゴリズムとの違い (14,9) (14,9) (14,9) (15,16) 先ほどの確定操作 (17,6) (17,15) 6 d (5,2) 既存の確定操作 (14,9) (15,16) (17,6) (17,15) 6 d (5,2) アルゴリズム研究会
計算量の算定 P:パレート解の数の上限 →各点のラベル数の上限=P →全体で確定されるラベル数の上限=nP →各点でのラベル集合の更新回数=nPn ラベルをまとめて更新(既存) ラベル集合を時間の 昇順のリストで保存 →O(P) →O(P2)【制約がk本の場合】 ラベルを1つ更新(新規) ラベル集合を時間の 昇順のリストで保存 →O(P) →O(P) 【制約がk本の場合】 ラベル集合を平衡木で保存 →O(log P) →無理? 【制約がk本の場合】 kは定数と見なしている アルゴリズム研究会
どのラベルを 確定するか 探索にヒープを使っているため 総計算量(旧)→O(n2P(log n + P)) 総計算量(新)→O(n2P(log n + log P)) 総計算量の算定 P≦max{U, (n-1)×枝移動時間最大値}≡C 総計算量(旧)→O(n2C(log n + C)) 総計算量(新)→O(n2C(log n + log C)) Bellman-Ford法ベース O(nmC) 制約がk本の場合 C≡min{U1, U2,…, Uk,(n-1)×枝移動時間最大値} P≦Ck-1 総計算量(旧)→O(n2 Ck-1(log n + C2k-2)) 総計算量(新)→O(n2 Ck-1(log n + Ck-1)) (kは定数と見なしている) Bellman-Ford法ベース O(nmC2k-2) アルゴリズム研究会
2-3木 例えば,平衡木の中でも2-3木を使用 子の数は2あるいは3個 葉にのみラベルを保持 (1,9)~(8,1) (4,4) 根から葉への距離は一定 (1,9)~(3,7) (5,6)~(8,1) (1,9) (3,7) (5,6) (6,5) (8,1) 新要素がパレート解か?→O(log P) 新要素の挿入→ O(log P) パレート解でなくなるものの除去→O(P log P)→O(log P) 内点に子孫の区間を保持 アルゴリズム研究会
予備(パレート解ラベル集合判定)実験 [1,n]2上の点を一様にn回発生,それをラベルとして更新 実験結果(10回試行した平均値) 計算時間(秒)(対数) 平衡木 リスト 平衡木 リスト n(対数) アルゴリズム研究会
[1,n]2の対角領域に点を一様にn回発生,それをラベルとして更新[1,n]2の対角領域に点を一様にn回発生,それをラベルとして更新 予備(パレート解ラベル集合判定)実験(やりなおし) 計算時間(秒)(対数) 10回試行した平均値 リスト 平衡木 n(対数) アルゴリズム研究会
ベンチマーク問題を用いた計算実験 Beasley And Christofides [1989]より アルゴリズム研究会
ベンチマーク問題を用いた計算実験 問題が小さすぎて参考にならない アルゴリズム研究会
計算実験(問題例の説明) 一辺の点数n(例の場合3) と 枝の移動時間・移動費用の最大値MAX を設定 出発 地点 一様乱数[0,MAX] により設定 1 2 3 始点は1,終点はn2 6 4 5 費用上限はn・MAX 目的 地点 9 8 7 アルゴリズム研究会
点数100(=10×10),枝数約400,10回試行 計算実験結果 旧方式はラベルが多い,確定回数が少ないとは限らない 新方式はリストの方が速い アルゴリズム研究会
平均出次数約4,10回試行 計算実験結果 平衡木を使った方が遅い,平均ラベル数が少なすぎ 勝つまでやっても意味はないのでこのへんで アルゴリズム研究会
まとめ Dijkstra法ベースのアルゴリズムを改良 計算実験の結果、平衡木を使う方法は それほど速くなかった。 アルゴリズム研究会
参考文献 Ahuja, Magnanti and Orlin, Lagrangian relaxation and network optimization, Network flows:Section16, Plentis holl, 1993. 主にLagrangu緩和に関する話題と,応用が載っている. Beasley and Christofides, An algorithm for the resource constrained shortest path problem, Networks, Vol. 19 (1989), pp. 379—394. ここではLagrangu緩和を下界とした分枝限定法を提案している. ベンチマーク問題も提供されている. Puri and Tripakis, Algorithms for the multi-constrained routing problem, Proceedings of SWAT2002, pp.338—347. Bellman-Ford法に基づく多項式時間近似スキームを提案している. 擬多項式時間アルゴリズムも提案している. 計算実験結果も報告している. アルゴリズム研究会