Покривач чворова

С Википедије, слободне енциклопедије

У области математике - теорија графова, покривач чворова за дати граф је такав скуп чворова да су све гране тог графа инцидентне макар једном чвору тог скупа. Проблем налажења минималног покривача чворова је типичан оптимизациони проблем у рачунарству и стандардан је пример НП-тешког оптимизационог проблема који се решава апроксимационим алгоритмом. Одговарајући проблем одлучивања, постојање покривача чворова, је један од Карпових 21 НП-комплетних проблема и самим тиме један од основних НП-комплетних проблема у теорији комплексности.

Проблем минималног покривача чворова се може дефинисати као проблем линеарног програмирања чији је одговарајући дуални линеарни програм одређивање максималног упаривања.

Дефиниција[уреди | уреди извор]

Формално, покривач чворова неусмереног графа је подскуп V′ од V такав да ако грана (u, v) припада графу G, онда u припада V′ или v припада V′ или оба чвора припадају V′. Скуп V′ "покрива" гране графа G. Следеће две фигуре приакзују примере покривача чворова два графа (чворови скупа V' су означени црвеном бојом).

Минимални покривач чворова је најмањи такав скуп. Грчким словом означавамо величину минималног скупа покривача чворова. Следеће две фигуре показују минимални скуп покривача чворова.

Примери[уреди | уреди извор]

  • Скуп свих чворова је покривач чворова.
  • Чворови било којег скупа независних грана чине покривач чворова.
  • За потпуни бипартитивни граф постоји минимални покривач чворова величине .

Особине[уреди | уреди извор]

  • Скуп чворова V' је покривач чворова ако његов комплемент у односу на скуп свих чворова чини скуп несуседних чворова.
  • Број чворова графа је једнак укупном броју чворова минималног покривача грана и максималног скупа несуседних чворова.

Проблем израчунљивости[уреди | уреди извор]

Проблем налажења минималног покривача чворова је оптимизациони проблем проналажење најмањег покривача чворова датог графа.

УЛАЗ: Граф
ИЗЛАЗ: Најмање такво да граф има покривач чворова величине .

За проблем дефинисан као проблем одлучивања, назива се проблем покривача чворова:

УЛАЗ: Граф природни број .
УПИТ: Да ли граф поседује покривач чворова величине највише ?

Проблем одлучивости покривача чворова је НП-комплетан проблем: је један од Карпових 21 НП-комплетних проблема. Најчешће је коришћен при теорији комплексности при конструкцији доказа НП-тешких проблема.

ЦЛП формулација[уреди | уреди извор]

Придружимо сваком чвору функцију цене . Проблем тежина минималног покривача чворова се дефинише следећим целобројним линеарним програмом (ЦЛП).[1]

minimize    (минимизује укупну цену)
subject to for all (покрива сваку грану графа)
for all . (сваки чвор или припада покривачу или не припада)

Овако дефинисан ЦЛП припада општој класи ЦЛП проблема покривача.

Тачно израчунавање[уреди | уреди извор]

Проблем одлучивости покривача чворова је НП-комплетан, што значи да је мало вероватно да постоји алгоритам који то ефикасно решава. НП-комплетност се доказује редукцијом проблема 3-задовољивости или редукцијом проблема клике. Покривач чворова остаје НП-комплетан чак и у тростепеном графу[2] и у планарном графу степена највише 3.[3][4]

Код бипартитивних графова, једнакост проблема покривача чворова и проблема максималног упаривања описаног Кониговом теоремом омогућава решавање проблема покривача грана бипартитивног графа у полиномијалном времену.

Код стабала, похлепни алгоритам налази минимални покривач чворова у полиномијалном времену.[5]

Израчунавање апроксимацијом[уреди | уреди извор]

Могуће је пронаћи другостепену апроксимацију константним додавањем оба чвора изабране гране у покривач чворова, а затим уклањати их са графа. Дакле, проналазимо максимално упаривање М похлепним алгоритмом и конструишемо покривач чворова C који садржи ова краја свих грана из M. На следећој фигури је максимално упраривање M означено црвеном бојом, а покривач чворова C плавом.

Скуп C, конструисан на овај начин, је покривач чворова: претпоставимо да грана e није покривена скупом C; тада је M ∪ {e} упаривање и e ∉ M, што је контрадикторно претпоставци да је M маскимално упаривање. Даље, ако e = {uv} ∈ M, тада покривач чворова, укључујући и оптимални покривач, мора садржати u или v (или оба) јер у супротном грана e не би била покривена. Дакле, Оптимални покривач чворова садржи макар један чвор сваке гране из M и укупно, скуп C је највише два пута већи од оптималног покривача чворова.

Овај алгоритам су независно осмислили Фаниша Гаврил и Михалис Јанакакис.[6]

Напредније технике показују да постоји апроксимациони алгоритам са нешто бољим степеном оптимизације. Познат је апроксимизациони алгоритам са степеном апроксимације .[7]

Неапроксимабилност[уреди | уреди извор]

Није познат алгоритам са бољим костантним степеном апроксимације од горепоменутог. Проблем минималног покривача чворова је АПИкс-комплетан, што значи да се не може произвољно добро осим ако је П = НП. Користећи технике ПЦБ теореме, 2005. године су Динур и Сафра изнели доказ да се минимални покривач чворова не може апроксимизовати степеном мањим од 1.3606 за довољно велики степен чворова осим ако је П = НП.[8]

Премда је проналажење минималног покривача чворова еквивалентно налажењу максималног независног скупа, као што је горе описано, ова два проблема нису еквивалентна у смислу очувања апроксимабилности: Проблем независног скупа нема апроксимацију константног степена осим ако важи П = НП.

Псеудо кôд[уреди | уреди извор]

АПРОКСИМАЦИЈА_ПОКРИВАЧА_ЧВОРОВА(G)
C=∅
E'= G.E
докле год је E'≠ ∅

нека је (u,v) произвољна грана из E'
C = C ∪ {u,v}
избаци из E' сваку грану која је инцидентна или са u или са v

врати C
[9][10]

Покривач чворова код хиперграфова[уреди | уреди извор]

За дату колекцију скупова, скуп који у пресеку са свим скуповима те колекције садржи макар један елемент се назива ударнички скуп и НП-тежак проблем је проблем налажења ударничког скупа најмање величине тј минималног ударничког скупа. Пресликавање скупова такве колекције на хиперграф се може схватити природном генерализацијом проблема покривача чворова на хиперграфове и често се назива покривач чворова хиперграфа, а у комбинаторном смислу обилазак хиперграфа. Нотације ударничког скупа и скупа покривача чвурова су идентичне.

Формално, нека је H = (VE) хиперграф са скупом чворова V и скупом хиперграна E. Тада се скуп S ⊆ V назива ударнички скуп за H ако за све гране e ∈ E важи S ∩ e ≠ ∅. Проблеми теорије израчунљивости минимални ударнички скуп и ударнички скуп дафинисани су исто као у случају графова. Проблем покривача чворова обичног графа је специјалан случај проблема покривача чворова хиперграфа чије су гране степена 2.

Ако ограничимо проблем величином d, проблем налажења минималног d-ударничког скупа се решава d-апроксимационим алгоритмом. Ако претпоставимо предлог јединствених игара, онда је ово најбољи апроксимациони алгоритам констатног степена јер би иначе постојала могућност побољшања апроксимације на d − 1.

Ударнички скуп и покривач чворова[уреди | уреди извор]

Проблем ударничког скупа је еквивалентат проблему покривача чворова: Инстанца проблема покривача чворова се може посматрати кроз произвољни бипартитивни граф, са скуповима представљеним чворовима лево, елементима универзума представљеним чворовима десно, при чему гране представљају припадност елемената тим скуповима. Задатак је пронаћи подскуп левих чворова минималне кардиналности који покривају све десне чворове. У проблему ударничког скупа, задатак је покрити све леве чворове користећи минимални подскуп десних чворова. Свођење једног проблема на други се постиже заменом једног скупа чворова другим.

Примене[уреди | уреди извор]

Пример практичне примене користећи проблем ударничког скупа се примећује код потребе за ефикасном динамичком детекцијом услова трке.[11] У овом примеру, сваки пут када се уписује у глобалну меморију, тренутна нит као и скуп катанаца које држи та нит ће бити сачувани. Код детекције засноване на скупу катанаца, ако друга нит покуша да записује податке на тој локацији и нема трке, то значи да она држи макар један заједнички катанац са свим нитима које су претходно писале на том месту. Дакле, величина ударничког скупа представља минимални скуп катанаца потребан како би трка била немогућа. Ово је корисно зарад елиминације редудантних покушаја писања, јер се велики скупови катанаца сматрају непожељним у пракси.

Референце[уреди | уреди извор]

  1. ^ Vazirani 2001, стр. 122–123
  2. ^ Garey, Johnson & Stockmeyer 1974
  3. ^ Garey & Johnson 1977
  4. ^ Garey & Johnson 1979, pp. 190 and 195.
  5. ^ Schulz, A. „Correctness-Proof of a greedy-algorithm for minimum vertex cover of a tree”. CS Stack Exchange. Приступљено 8. 07. 2014. 
  6. ^ Papadimitriou & Steiglitz 1998, pp. 432, mentions both Gavril and Yannakakis. Garey & Johnson 1979, pp. 134, cites Gavril.
  7. ^ Karakostas 2004
  8. ^ Dinur & Safra 2005
  9. ^ Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Stein, Clifford (2013). Introduction to Algorithms. Delhi: PHI Learning Pvt. Ltd. стр. 1109. 
  10. ^ Chakrabarti, Amit. „Approximation Algorithms: Vertex Cover” (PDF). http://www.cs.dartmouth.edu/. Приступљено 21. 02. 2005.  Спољашња веза у |website= (помоћ)
  11. ^ O'Callahan & Choi 2003

Литература[уреди | уреди извор]

  • Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Stein, Clifford (2013). Introduction to Algorithms. Delhi: PHI Learning Pvt. Ltd. стр. 1109.