跳至內容

英文维基 | 中文维基 | 日文维基 | 草榴社区

徑寬

維基百科,自由的百科全書

圖論中,G徑分解(path decomposition)是G的「加粗」路徑圖表示,[1]G徑寬(pathwidth)是衡量形成G的路徑被加粗的程度。更正式地說,徑分解是G頂點子集序列,使每條邊的端點出現在某一子集中,並使每個頂點都出現在子集連續子序列中,[2]徑寬等於這樣的分解中最大集的大小減一。 徑寬也叫做區間厚度(interval thickness,等於G區間父圖中的最大團大小減一)、頂點分隔數(vertex separation number)或結點搜索數(node searching number)。[3]

徑寬與徑分解同樹寬樹分解關係密切,在圖子式理論中起關鍵作用:在圖子式下封閉、不含所有森林的圖族可描述為徑寬有界,[2]子式閉圖族的一般結構理論中出現的「渦」(vortex)的徑寬也有界。[4]徑寬與徑寬有界圖在超大規模集成電路設計、圖繪製計算語言學等領域也有應用。

計算任意圖的徑寬、甚至精確近似徑寬都是NP困難的。[5][6]不過,這問題是固定參數可解的:測試圖的徑寬是否為k,耗時與圖的大小呈線性關係,而與k呈上指數關係。[7]另外,對之類的特殊圖,徑寬可在多項式時間內算得,而不依賴於k[8][9] 對圖的徑分解使用動態規劃,可以將圖算法中很多問題在徑寬有界圖上高效解決。[10]徑分解也可測量樹寬有界圖上動態規劃算法的空間複雜度[11]

定義

[編輯]
徑寬為2的例圖G,其徑分解寬度為2。圖像下半部是相同的圖與徑分解,添加了顏色以示強調。(本例改編自Bodlaender (1994a),添加了記號)

Neil Robertson and Paul Seymour (1983圖子式系列論文的第一篇中,將圖G的徑分解定義為G的頂點子集序列,滿足兩條屬性:

  1. G中每條邊,存在i使邊的兩端點都屬於子集

第二條性質等價於要求包含任意特定頂點的子集構成整個序列的連續子列。用系列論文後期的話來說,徑分解是樹分解,其中分解的底樹T是路徑圖。 徑分解的寬度與樹分解類似,是G的徑寬是G的徑分解的最小寬度。在徑寬的大多數應用中,的大小減不減一沒什麼差別,主要是為了使路徑圖的徑寬等於1。

其他特徵

[編輯]

Bodlaender (1998)所描述的,徑寬可用許多等價方法表徵。

粘合序列

[編輯]

徑分解可表述為圖的序列,找到來自序列中連續圖的頂點對,並將圖粘合在一起,所有粘合的結果就是G。在徑分解的第一個定義中,圖可看作是集合誘導子圖,連續(successive)誘導子圖中的兩頂點被G中相同頂點誘導時,就會被粘在一起;反之,可以把集合恢復為圖的頂點集。則徑分解的寬度比某一圖的最大頂點數少1。[2]

區間厚度

[編輯]
徑寬為2的區間圖,而4個最大團ABC、ACD、CDE、CDF的大小為3。

任意圖G的徑寬等於含G(以G為子圖)的區間圖的最小團數減一。[12]即,對G的每種徑分解,都能找到G的區間子圖;對G的每個區間父圖,都能找到G的徑分解,使分解的寬度比區間圖團數小1。

假設給出了G的徑分解。則可將分解的結點表為直線上的點(按路徑順序),並將每個頂點v表示為以這些點為端點的閉區間。這樣,包含v的徑分解結點就對應v在區間中的代表點。G頂點形成的區間交圖是包含G的區間圖,其最大團由包含代表點的區間集給出,大小比G的徑寬大1。

G是某區間圖的子圖,團數,則G有寬p的徑分解,其結點由區間圖的最大團給出。例如,圖中的區間圖及其區間表示的徑分解有5個結點,分別對應5個最大團ABC、ACD、CDE、CDF、FG;最大團大小為3,這徑分解的寬度為2。 徑寬與區間厚度之間的等價關係同樹寬與弦圖(給定圖是弦圖的子圖)的最小團數(減一)的等價關係非常相似。區間圖是弦圖的特例,弦圖可表為共同樹的子樹的交圖,這類似於區間圖是路徑子徑的交圖。

頂點分隔數

[編輯]

設圖G的頂點是線性有序的。則,G的頂點分隔數是滿足下列條件的最小數s:對頂點v,最多s個頂點在排序中先於v,但有v或更靠後的頂點相鄰。 G的頂點分隔數是G的任意線性排序的最小頂點分隔數。頂點分隔數由Ellis, Sudborough & Turner (1983)定義,等於G的徑寬。[13] 這源於前述的與區間圖團數的等價關係:若G是區間圖I的子圖,並以所有區間端點都分離的方式表示(如圖所示),則I的區間左端點排序的頂點分隔數比I的團數小1。反過來,從G的線性排序可推導出一種區間表示:頂點v的區間左端點是其在排序中的位置,右端點是v在排序中最後一個鄰居的位置。

結點搜索數

[編輯]

圖上的結點搜索策略是追逃對策的一種形式,當中一組搜索者合作追蹤藏在圖中的逃犯。搜索者被置於圖的頂點上,逃犯可能在任意邊上,位置與移動對搜索者不可見。每個回合中,搜索者的部分或全部可從頂點移動到另一頂點(任意移動,不必沿邊),逃犯可以沿不經過搜索者頂點的任意路徑移動。逃犯所在邊的兩端點都被搜索者佔據時,就被抓獲。圖的結點搜索數是必然能抓到逃犯的最少搜索者數。如Kirousis & Papadimitriou (1985)所示,圖的結點搜索數等於其區間厚度。搜索者的最優策略是不斷移動搜索者,使他們在連續回合中形成具有最小頂點分隔數的線性排序的分隔集。

[編輯]
毛蟲樹,徑寬為1的最大圖。

徑寬為kn頂點圖至多有條邊,是最大k徑寬圖(即徑寬為k、無論怎樣添加邊都必改變徑寬的圖)的邊數。徑寬為k的最大圖要麼是k徑圖要麼是k毛蟲圖,它們是兩種特殊的k樹。k樹是恰有最大團(含個頂點)的弦圖;在本身不是團的k樹中,每個最大團要麼將圖分隔成多個部分,要麼包含單個葉頂點(只屬於一個最大團的頂點)。k徑圖是至少有兩葉的k樹,k毛蟲圖是可分割維k徑與一組k葉的k樹,其中每片葉還與k徑中的獨立k團相鄰。徑寬為1的最大圖是毛蟲樹[14]

由於徑分解是樹分解的特例,徑寬不小於樹寬,且不大於割寬,即在圖頂點的最優線性排列中,前後頂點組之間割邊的最小數。這是因為,頂點分隔數即前後頂點組的鄰接數不大於割邊數。[15]出於類似原因,割寬不大於徑寬乘頂點的最大度[16]

任意n頂點森林都有徑寬[17]例如,對一個森林,總能找到恆定多的頂點,使得去掉它們後形成至多有個頂點的兩片子森林。如此遞歸地分隔子森林,將分隔頂點置於兩者之間,形成的線性排列具有對數頂點搜索數。此技術用於樹分解時,可知,若n頂點圖G的樹寬為t,則G的徑寬是[18]由於外平面圖系列並行圖哈林圖的樹寬都有界,它們的徑寬最多為對數的。

此外,徑寬還通過線圖,同團寬割寬有關係。G的邊在其線圖中都有對應的頂點,當G中相應的兩邊有共同端點時,中的兩頂點就是相鄰的。若且唯若圖族的線圖的線性團寬(用鄰接1個新頂點的操作取代了團寬的不交並操作)有界,圖族的徑寬有界。[19]若某3及以上個頂點的連通圖的最大度為3,則其割寬等於線圖的頂點分隔數。[20]

平面圖的徑寬最多與頂點數的平方根成正比。[21]找到具有這種寬度的徑分解,一種方法是(與上述森林的對數寬徑分解類似)用平面分隔定理找到個頂點的集合,其將圖分隔為至多有個頂點的兩個子圖,如此遞歸地分隔子圖,最後將兩子圖的遞歸徑分解連接起來。同樣的技術也適用於類似分離器定理成立的任何一類圖。[22]與平面圖一樣,任何固定的子式閉圖族中的圖都有大小為的分隔子,[23]因此此類圖族中圖的徑寬也是。對某類平面圖,圖的徑寬與其對偶圖的徑寬必須在一常數因子範圍內,對於雙連通外平面圖[24]與多面體圖[25],這種形式的邊界是已知的。2連通平面圖的對偶圖的徑寬小於線圖的徑寬。[26]至於在其他情形下,平面圖徑寬與對偶圖徑寬是否總相差某常數因子,仍是未知的。

在某些類的圖中,徑寬與樹寬總相等。已證明的有余圖[27]置換圖[28]可比圖[29]區間序的可比圖。[30]

立方圖中,或更廣義地在任何最大頂點度為3的圖中,徑寬不大於,其中n是頂點數。存在徑寬為的立方圖,但如何縮小這下界與上界之間的差距,目前還不得而知。[31]

計算徑分解

[編輯]

確定給定圖的徑寬是否大於k的問題是NP完全的(k也是輸入)。[5]計算任意n頂點圖徑寬的最壞情形的最優時間邊界為c是常數。[32]不過,已經有幾種算法可在徑寬較小、輸入圖類別有限或近似的情形下更高效地計算徑分解。

固定參數可解

[編輯]

徑寬是固定參數可解的:對任意常數k,都可測試徑寬是否大於k,若不大於k,則在線性時間內找到寬k的徑分解。[7]一般來說,這類算法分兩階段運行。第一階段,假設圖的徑寬為k,以找到並非最優的徑分解或樹分解,寬度可作為k的函數而變為約束。第二階段,對這分解運用動態規劃算法,以找到最優分解。然而,已知的這類算法的時間界限是的指數級,除了最小的k外,都是不切實際的。[33]對於的情形,de Fluiter (1997)給出了基於2徑寬圖的結構分解的精確限行時間算法。

特殊圖類

[編輯]

Bodlaender (1994)調查了計算各種特殊圖類的徑寬的複雜性。若圖G是有界度圖、[34]平面圖[34]有界度平面圖、[34]弦圖[35]弦多米諾、[36]可比圖[29]二分距離遺傳圖[37],確定圖G的徑寬是否最大是k的問題仍是NP完全的。對於包含二分距離遺傳圖的圖族(二分圖、弦二分圖、距離遺傳圖、循環圖之類),也是NP完全的。[37]

不過,對於樹與森林,徑寬可在線性時間內算得。[9]對樹寬有界圖族(系列並行圖外平面圖哈林圖[7]裂圖[38]、弦圖之補[39]置換圖[28]余圖[27]圓弧圖[40]、區間序的可比圖[30]區間圖,也可在多項式時間內計算出來。這種情形下,徑寬比覆蓋圖的區間表示中所有點的最大區間數小1。

近似算法

[編輯]

將圖的徑寬近似到加常數範圍內,是NP難的。[6] 已知近似率最佳的多項式時間近似算法是[41] 關於計算徑寬的早期近似算法,見Bodlaender et al. (1992)Guha (2000);關於受限圖類的近似計算,見Kloks & Bodlaender (1992)

圖子式

[編輯]

G子式是由G通過收縮邊、移除邊、移除頂點得到的另一張圖。圖子式有深奧的理論,其中幾個重要結果涉及徑寬。

排除森林

[編輯]

若圖族F對取子式封閉(即F成員的子式還在F中),則由羅伯森–西摩定理F的特徵是在禁子式有限集X中沒有任何子式。[42]例如,瓦格納定理指出,平面圖是既沒有完整圖也沒有完全二分圖作為子式的圖。很多時候,F的性質與X的性質密切相關,此類的第一個結果由Robertson & Seymour (1983)提出,[2]將有界徑寬與禁子式族中森林的存在聯繫起來。具體來說,若存在常數p使F中圖的徑寬不大於p,則稱圖族F具有有界徑寬。那麼,若且唯若F的禁子式集X至少包括一個森林時,子式閉族F具有有界的徑寬。

從一個方向來看,這結果很容易證明:若X不含森林,則「無X子式圖」的徑寬便無界。因為這時,無X子式圖將包含所有森林,特別是包括完美二叉樹。而一棵層的完美二叉樹的徑寬為k,所以這時無X子式圖的徑寬無解。從另一方向看,若X包含n頂點森林,則無X子式圖的徑寬不大於[43]

徑寬有界的障礙

[編輯]
徑寬為1的圖的禁子式。

徑寬不大於p的性質本身對取子式封閉:若G的徑分解寬度不大於p,則從G中刪去任何邊,同一徑分解仍有效,且可以從G及其徑分解中刪去任意頂點而不增加寬度。同樣,通過合併表示收縮後邊的兩端點的子徑,也可在收縮邊時不增加分解寬度。因此,徑寬至多為p的圖可用排除子式的集合描述。[42][44]

雖然必然包括森林,但並不是說中的所有圖都是森林:例如,包含2張圖,一個7頂點樹與三角。而中的樹集可以精確描述:它們是中三棵樹通過邊,連接新的根頂點與3棵小樹中任意頂點而形成的樹。例如,中的7頂點樹就是這樣由中的2頂點樹(一條邊)組成的。基於這種構造,可以證明中的禁子式數至少為[44]已計算出2徑寬圖的完備禁子式集,其中包含110個圖。[45]

結構理論

[編輯]

子式閉圖族的圖結構定理指出,對任意圖族F,其中的圖可分解為能嵌入虧格有界曲面上的圖的團和,且團和的每個分量都有有界多的頂點(apex)與渦(vortex)。這裏的頂點可能與其組分中任何頂點相鄰,渦是徑寬有界圖,粘合到某組分的虧格有界嵌入的面上。渦所嵌入面周圍的頂點的循環排序必須與渦的徑分解相容,即,打破循環、形成線性排序必然產生頂點分隔數有界的排序。[4]這一理論中,徑寬與任意子式閉圖族密切相關,具有重要的算法應用。[46]

應用

[編輯]

超大規模集成電路

[編輯]

超大規模集成電路設計中,頂點分隔問題最初是將電路分為子系統的方法,子系統邊界有少量元件。[34]

Ohtsuki et al. (1979)使用區間厚度模擬VLSI一維佈局所需的軌道數,此佈局由網絡系統相互連接的模塊組成。在他們的模型中,頂點代表網,若兩網都連接到同一模塊,就將兩頂點由邊相連;也就是說,若將模塊與網視作超圖的結點與超邊,則由它們形成的圖就是超圖的線圖。這超圖的區間表示與着色描述了沿水平軌道(一種顏色對應一條軌道)系統的網的排列,使模塊可沿軌道以線性順序排列,並連接到相應的網。區間圖都是完美圖[47],表明這類最佳排列中,所需顏色數等於網圖的區間完備化的團數。

門矩陣佈局[48]是一種用於布爾邏輯電路的CMOS VLSI佈局。當中,信號沿「線」(垂直線段)傳播,而電路的每個門則由沿水平線段的一系列器件特徵構成。因此,代表門的水平線段須與代表門輸入輸出的線路的垂直線段交叉。與Ohtsuki et al. (1979)的佈局類似,通過計算以線路為頂點,以共享同一門的線對為邊的圖的徑寬,可以找到使排列線路的垂直軌道數最小的佈局。[49]這種算法方法也可為可程式邏輯陣列的摺疊問題建模。[50]

圖繪製

[編輯]

徑寬在圖繪製中有多個應用:

  • 給定交叉數的最小圖的徑寬受交叉數函數的約束。[51]
  • 樹的頂點可畫在多少條平行線上而邊不交(根據對相鄰頂點在線序列上擺放方式的各種自然限制),與樹的徑寬成正比。[52]
  • Gk交叉h層繪圖是將G的頂點放置在h條水平線上,邊在其間以單調多邊形路徑排列,使得最多有k處交叉。具有這種繪製的圖的徑寬由hk的函數約束。於是,hk為常值時,可在線性時間內確定圖是都具有k交叉h層繪製。[53]
  • n頂點、徑寬為p的圖可嵌入3維格,使得邊(表為格點間的直線段)不交。於是,徑寬有界圖具有此種線性體積嵌入。[54]

編譯器設計

[編輯]

高級語言編譯過程中,徑寬見於重排直線代碼序列(即無控制流分支或循環的代碼)問題,使代碼算得的所有值都可放在寄存器中,而不必溢出到主內存中。這種應用中,我們將待編譯代碼表為有向無環圖,其中結點是代碼的輸入輸出值。這個DAG中,結點x到結點y的邊表示x值是操作了y的輸入之一。此DAG的頂點的拓撲排序表示代碼的有效重排,在給定排序中評估代碼所需的寄存器數由排序的頂點分隔數給出。[55]

對表示寄存器數的任意定值w,可在限行時間內確定一段直線代碼能否重排,以便用不多於w個寄存器求值。若拓撲排序的頂點分隔數最多為w,則所有排序中的最小頂點分隔也不會更大,於是忽略DAG方向形成的無向圖的徑寬不大於w。可用已知的固定參數可解算法計算徑寬,若是,則可在假設w為常數的線性時間內找到無向圖的徑分解。找到徑分解,就可用動態規劃,在線性時間內找到寬w的拓撲排序。[55]

語言學

[編輯]

Kornai & Tuza (1992)描述了徑寬在自然語言處理中的應用。句子被建模為圖,頂點表示詞,邊表示詞之間的關係。例如,若形容詞修飾了名詞,則圖中這兩個詞之間就會有一條邊。Kornai和Tuza認為,由於人類的短時記憶能力有限,[56]這種圖的徑寬一定有界(更具體地說,他們認為是6),否則人類將無法正確解析語言。

指數算法

[編輯]

圖算法中的很多問題都可通過對徑分解進行動態規劃,在徑寬較小的圖上高效解決。[10]例如,若給定n頂點圖G的頂點的線性排序,就有可能在的時間內找到G的最大獨立集。[31]在徑寬有界圖上,這種方法會產生以徑寬為參數的固定參數可解算法。[49]這種結果在文獻中不常見,因為已經包含在以樹寬為參數的類似算法;然而,即使在基於樹寬的動態規劃算法中,徑寬也會出現衡量算法空間複雜度的過程中。[11]

同樣的動態規劃方法也可用於徑寬無界圖,產生以指數時間解決無參圖問題的算法。例如,將這種方法與立方圖徑寬為的事實相結合,可以發現在立方圖中,最大支配集的構造耗時,比以往方法更快。[31]類似方法還可改進立方圖中最大割與最小支配集問題的指數時間算法,[31]及其他一些NP難優化問題的指數時間算法。[57]

另見

[編輯]

註釋

[編輯]
  1. ^ Diestel & Kühn (2005).
  2. ^ 2.0 2.1 2.2 2.3 Robertson & Seymour (1983).
  3. ^ Bodlaender (1998).
  4. ^ 4.0 4.1 Robertson & Seymour (2003).
  5. ^ 5.0 5.1 Kashiwabara & Fujisawa (1979); Ohtsuki et al. (1979); Lengauer (1981); Arnborg, Corneil & Proskurowski (1987).
  6. ^ 6.0 6.1 Bodlaender et al. (1992).
  7. ^ 7.0 7.1 7.2 Bodlaender (1996); Bodlaender & Kloks (1996)
  8. ^ Bodlaender (1994).
  9. ^ 9.0 9.1 Möhring (1990); Scheffler (1990); Ellis, Sudborough & Turner (1994); Peng et al. (1998); Skodinis (2000); Skodinis (2003); Coudert, Huc & Mazauric (2012).
  10. ^ 10.0 10.1 Arnborg (1985).
  11. ^ 11.0 11.1 Aspvall, Proskurowski & Telle (2000).
  12. ^ Bodlaender (1998), Theorem 29, p. 13.
  13. ^ Kinnersley (1992); Bodlaender (1998), Theorem 51.
  14. ^ Proskurowski & Telle (1999).
  15. ^ Korach & Solel (1993), Lemma 3 p.99; Bodlaender (1998), Theorem 47, p. 24.
  16. ^ Korach & Solel (1993), Lemma 1, p. 99; Bodlaender (1998), Theorem 49, p. 24.
  17. ^ Korach & Solel (1993), Theorem 5, p. 99; Bodlaender (1998), Theorem 66, p. 30. Scheffler (1992)n頂點森林的徑寬提供了更緊的上界:
  18. ^ Korach & Solel (1993), Theorem 6, p. 100; Bodlaender (1998), Corollary 24, p.10.
  19. ^ Gurski & Wanke (2007).
  20. ^ Golovach (1993).
  21. ^ Bodlaender (1998), Corollary 23, p. 10.
  22. ^ Bodlaender (1998), Theorem 20, p. 9.
  23. ^ Alon, Seymour & Thomas (1990).
  24. ^ Bodlaender & Fomin (2002); Coudert, Huc & Sereni (2007).
  25. ^ Fomin & Thilikos (2007); Amini, Huc & Pérennes (2009).
  26. ^ Fomin (2003).
  27. ^ 27.0 27.1 Bodlaender & Möhring (1990).
  28. ^ 28.0 28.1 Bodlaender, Kloks & Kratsch (1993).
  29. ^ 29.0 29.1 Habib & Möhring (1994).
  30. ^ 30.0 30.1 Garbe (1995).
  31. ^ 31.0 31.1 31.2 31.3 Fomin & Høie (2006).
  32. ^ Fomin et al. (2008).
  33. ^ Downey & Fellows (1999), p.12.
  34. ^ 34.0 34.1 34.2 34.3 Monien & Sudborough (1988).
  35. ^ Gustedt (1993).
  36. ^ Kloks, Kratsch & Müller (1995). 弦多米諾是頂點都屬於至多2個最大團的弦圖。
  37. ^ 37.0 37.1 Kloks et al. (1993).
  38. ^ Kloks & Bodlaender (1992); Gustedt (1993).
  39. ^ Garbe (1995)將此成果歸功於Ton Kloks的博士論文(1993);Garbe對區間序的可比圖的多項式時間算法推廣了結果,而弦圖屬於此類可比圖。
  40. ^ Suchan & Todinca (2007).
  41. ^ Feige, Hajiaghayi & Lee (2005).
  42. ^ 42.0 42.1 Robertson & Seymour (2004).
  43. ^ Bienstock et al. (1991); Diestel (1995); Cattell, Dinneen & Fellows (1996).
  44. ^ 44.0 44.1 Kinnersley (1992); Takahashi, Ueno & Kajitani (1994); Bodlaender (1998), p. 8.
  45. ^ Kinnersley & Langston (1994).
  46. ^ Demaine, Hajiaghayi & Kawarabayashi (2005).
  47. ^ Berge (1967).
  48. ^ Lopez & Law (1980).
  49. ^ 49.0 49.1 Fellows & Langston (1989).
  50. ^ Möhring (1990); Ferreira & Song (1992).
  51. ^ Hliněny (2003).
  52. ^ Suderman (2004).
  53. ^ Dujmović et al. (2008).
  54. ^ Dujmović, Morin & Wood (2003).
  55. ^ 55.0 55.1 Bodlaender, Gustedt & Telle (1998).
  56. ^ Miller (1956).
  57. ^ Kneis et al. (2005); Björklund & Husfeldt (2008).

參考文獻

[編輯]