Descompunerea modulară este descompunerea unui grafic în subseturi de vârfuri, numite module. Un modul este o generalizare a unei componente conexe a unui grafic. Spre deosebire de componentele de conectivitate, totuși, un modul poate fi propriul său subset al altuia. Prin urmare, modulele conduc la o descompunere recursivă (ierarhică) a graficului, nu doar la partiții.
Variante de descompunere modulară există pentru graficele nedirecționate și pentru graficele direcționate . Pentru fiecare grafic nedirecționat, o astfel de descompunere este unică.
Noțiunea poate fi generalizată la alte structuri (cum ar fi graficele direcționate) și este utilă pentru dezvoltarea algoritmilor eficienți pentru recunoașterea anumitor clase de grafice, pentru găsirea orientărilor tranzitive ale graficelor de comparabilitate , pentru probleme de optimizare pe grafice și pentru vizualizarea graficelor .
Conceptul de modul a fost redescoperit în multe domenii. Pentru acest concept s-au folosit denumirile multimi autonome , multimi omogene , intervale si multimi fractionare . Aparent, cea mai veche mențiune și prima descriere a coeficientilor modulari și a împărțirii grafurilor care apar în acest caz a fost în lucrarea lui Galai din 1967.
Modulul grafic este o generalizare a componentei conectate . O componentă conectată are proprietatea că este un set de vârfuri astfel încât orice membru nu este vecin cu niciun vârf care nu este în . O generalizare va fi, este un modul atunci când, pentru fiecare vârf , fie orice membru nu este vecin , fie orice membru este vecin .
În mod echivalent, este un modul dacă toți membrii au același set de vecini între vârfuri nu în .
Spre deosebire de componentele conectate, modulele unui graf sunt aceleași cu modulele complementului său , iar modulele pot fi „imbricate” - un modul poate fi propriul subset al altuia. Rețineți că mulțimea de vârfuri a unui grafic este un modul, la fel ca seturile singleton și mulțimea goală . Ele sunt numite module triviale . Graficul poate avea sau nu alte module. Un grafic se numește simplu dacă toate modulele sale sunt triviale.
În ciuda diferențelor, modulele păstrează proprietatea dorită a componentelor conectate, și anume că multe proprietăți ale subgrafului generate de o componentă conectată sunt independente de restul graficului. Un fenomen similar este observat pentru subgrafele generate de module.
Modulele grafice sunt deci de mare interes algoritmic. Un set de module imbricate, dintre care extinderea modulară este un exemplu, poate fi utilizat pentru a obține o soluție recursivă la multe probleme combinatorii de pe grafice, cum ar fi recunoașterea și găsirea orientării tranzitive a graficelor de comparabilitate , recunoașterea și găsirea reprezentării permutării graficelor de permutare. , recunoașterea dacă un grafic este un cograf , recunoașterea graficelor de interval și găsirea unei reprezentări de interval pentru acesta, definirea graficelor moștenite de distanță [1] și pentru vizualizarea graficului [2] . Ele joacă un rol important în demonstrarea teoremei grafului perfect [3] .
Pentru recunoașterea graficelor moștenite la distanță și a graficelor circulare , o generalizare suplimentară a descompunerii modulare, numită descompunere divizată [1] , este deosebit de utilă .
Pentru a evita ambiguitatea definiției de mai sus, oferim următoarea definiție formală a modulelor. . este un modul al unui grafic dacă:
, și toate singleton -urile pentru sunt module și sunt numite module triviale . Un grafic este simplu dacă toate modulele sale sunt banale. Componentele de conectivitate ale unui graf sau complementele acestora sunt, de asemenea, module ale unui graf .
este un modul grafic puternic dacă nu se suprapune (parțial) cu niciun alt modul grafic - modulul grafic este fie , fie , sau .
Dacă și sunt module disjunse, atunci este ușor de observat că fie orice membru este vecin al oricărui element al lui , fie niciun membru nu este adiacent vreunui membru al lui . Astfel, toate elementele a două module care nu se intersectează sunt fie adiacente , fie nu adiacente . Nu există o stare intermediară între aceste două extreme.
Având în vedere acest lucru, descompunerile modulare , în care fiecare clasă de descompunere este un modul, prezintă un interes deosebit. Să presupunem că este o descompunere modulară. Deoarece clasele de partiții nu se intersectează, adiacența lor formează un nou graf, graful coeficient , ale cărui vârfuri sunt termenii . Adică, fiecare vârf este un modul al graficului G, iar adiacența acestor module definește muchiile .
În figura de mai jos, vârfurile 1, vârfurile 2 până la 4, vârfurile 5, vârfurile 6 și 7 și vârfurile 8 până la 11 sunt modulare. În diagrama din dreapta sus, muchiile dintre aceste mulțimi arată coeficientii dați de descompunerea dată, în timp ce muchiile din mulțimi arată factorii corespunzători.
Partiții și sunt partiții modulare banale . este un grafic cu un singur vârf, în timp ce . Să presupunem că este un modul non-trivial. Apoi , submulțimea unui element este, de asemenea, o partiție modulară non-trivială . Astfel, existența oricăror module non-triviale implică existența unor partiții de module non-triviale. În general, majoritatea sau toți membrii pot fi module non-triviale.
Dacă este o partiție modulară non-trivială, atunci este o reprezentare compactă a tuturor marginilor care se termină în diferite clase de partiții . Pentru fiecare clasă de partiție subgraf generată de se numește factor și oferă o reprezentare a tuturor marginilor cu ambele capete în . Astfel, muchiile unui grafic pot fi reconstruite dacă se cunosc graficul coeficientului și factorii săi. Termenul de graf simplu provine din faptul că un graf simplu are doar coeficienti și factori banali.
Dacă este un multiplicator al coeficientului modulo , se poate dovedi că poate fi factorizat recursiv și coeficienti. Fiecare nivel de recursivitate produce un coeficient. Ca caz de bază, graficul are un singur vârf. Graficul poate fi reconstruit prin reconstruirea factorilor de jos, inversând etapele de partiţionare prin asamblarea factorilor cu câte la fiecare nivel.
În figura de mai jos, o astfel de descompunere recursivă este reprezentată ca un arbore, care reflectă una dintre modalitățile de a factoriza recursiv factorii de descompunere modulară inițială în partiții modulare mai mici.
Metoda de partiționare recursivă a unui grafic în factori și coeficienti poate să nu fie singura. (De exemplu, toate subseturile de vârfuri ale unui graf complet sunt module, ceea ce înseamnă că există multe moduri diferite de a descompune acel graf în mod recursiv.) Unele moduri de descompunere pot fi mai utile decât altele.
Din fericire, există o descompunere recursivă a unui grafic care reprezintă implicit toate modalitățile în care acesta poate fi descompus. Aceasta este modularizarea. Este în sine o modalitate de a descompune recursiv un grafic în câte, dar le include pe toate celelalte. Descompunerea prezentată în figura de mai jos este o descompunere specială a graficului dat.
Mai jos este o observație cheie pentru înțelegerea descompunerii modulare:
Dacă este un modul al graficului și este un submult al lui , atunci este un modul dacă și numai dacă este un modul al lui .
Gallai [4] a definit recursiv o descompunere modulară pe un graf cu multe vârfuri , după cum urmează:
Arborele final are un singur set de vârfuri grafice sub formă de frunze, care sunt cazul de bază. Un set de vârfuri de graf este un modul dacă și numai dacă este un nod arborescent sau o uniune de descendenți ai unui nod în serie sau paralel. Acest lucru atribuie implicit toate expansiunile modulare în partea de sus . În acest sens, arborele de descompunere modulară „concentrează în sine” toate celelalte modalități de a descompune recursiv un grafic în unele parțiale.
Structura de date pentru reprezentarea unui arbore de descompunere modular trebuie să suporte operațiuni care iau un nod ca intrare și returnează setul de vârfuri ale graficului pe care le reprezintă nodul. Modul evident de a face acest lucru este de a atribui fiecărui nod o listă de vârfuri în graficul pe care îl reprezintă nodul. Dat un pointer către un nod, setul de vârfuri ale graficului pe care le reprezintă nodul poate fi recuperat în timp . Cu toate acestea, o astfel de structură va necesita memorie în cel mai rău caz .
Alternativa de memorie este obținută prin reprezentarea arborelui de descompunere modulară cu orice structură de date standard bazată pe arbore înrădăcinat și etichetând fiecare frunză cu vârful graficului pe care îl reprezintă. Setul reprezentat de nodul intern este definit de setul de etichete ale frunzelor sale descendente. Este bine cunoscut faptul că orice copac înrădăcinat cu frunze are cel mult noduri interne. Puteți utiliza căutarea în profunzime, începând de la pentru a obține etichete ale frunzelor descendente la timp .
Fiecare nod este un set de vârfuri în grafic și, dacă este un nod intern, mulțimea de descendenți este o divizare , unde fiecare clasă divizată este un modul. Prin urmare, ele generează un coeficient în . Vârfurile acestui coeficient sunt elemente ale lui , deci pot fi reprezentate prin stabilirea muchiilor între copiii lui . Dacă și sunt doi termeni și , , atunci și sunt adiacente în dacă și numai dacă și sunt adiacente în cât. Pentru orice pereche de vârfuri de graf, aceasta este determinată de descendenții privați ai celui mai mare strămoș comun și în arborele de descompunere modulară. Prin urmare, o descompunere modulară etichetată ca coeficienti în acest fel oferă o reprezentare completă a graficului .
Multe probleme combinatorii pot fi rezolvate pe un grafic rezolvându-le separat pentru fiecare coeficient. De exemplu, este un grafic de comparabilitate dacă și numai dacă fiecare dintre acești coeficienti este un grafic de comparabilitate [4] [5] . Prin urmare, pentru a determina dacă un grafic este un grafic de comparabilitate, este suficient să verificați acest lucru pentru fiecare dintre câtetorii săi. De fapt, pentru a găsi orientarea tranzitivă a unui grafic de comparabilitate, este suficient să găsim orientarea tranzitivă a fiecăruia dintre coeficientii săi în descompunerea modulară [4] [5] . Un fenomen similar se găsește pentru graficele de permutare [6] , graficele de intervale [7] , graficele perfecte și alte clase de grafice. Unele probleme importante de optimizare combinatorie pe grafice pot fi rezolvate folosind strategii similare [8] .
Cografele sunt grafice care au doar noduri paralele sau secvențiale în arborele lor de descompunere modulară.
Primul algoritm de timp polinomial pentru calcularea arborelui de descompunere modulară a unui graf a fost publicat în 1972 [9] , iar algoritmii de timp liniar sunt acum disponibili [6] [10] .
Descompunerea modulară a graficelor direcționate poate fi obținută în timp liniar [11] .
Cu câteva excepții simple, orice graf cu o descompunere modulară netrivială are și o partiție oblică [12] .