Modulær nedbrydning er nedbrydning af en graf i delmængder af toppunkter, kaldet moduler. Et modul er en generalisering af en forbundet komponent i en graf. I modsætning til tilslutningskomponenter kan et modul dog være sin egen undergruppe af et andet. Moduler fører derfor til en rekursiv (hierarkisk) dekomponering af grafen, ikke kun partitioner.
Modulære dekomponeringsvarianter findes for urettede grafer og rettede grafer . For hver urettet graf er en sådan dekomponering unik.
Begrebet kan generaliseres til andre strukturer (såsom rettede grafer) og er nyttigt til at udvikle effektive algoritmer til at genkende visse klasser af grafer, til at finde transitive orienteringer af sammenlignelighedsgrafer , til optimeringsproblemer på grafer og til visualisering af grafer .
Konceptet med et modul er blevet genopdaget på mange områder. Til dette koncept blev navnene autonome mængder , homogene mængder , intervaller og brøkmængder brugt . Tilsyneladende var den tidligste omtale og den første beskrivelse af modulære kvotienter og opdelingen af grafer, der opstår i dette tilfælde, i Galais papir i 1967.
Grafmodulet er en generalisering af den tilsluttede komponent . En forbundet komponent har den egenskab, at den er et sæt toppunkter, således at ethvert medlem ikke er nabo til ethvert toppunkt, der ikke er i . En generalisering vil være, er et modul, når, for hvert toppunkt , enten ethvert medlem ikke er en nabo , eller ethvert medlem er en nabo .
Tilsvarende er et modul, hvis alle medlemmer har det samme sæt af naboer blandt hjørner, der ikke er i .
I modsætning til forbundne komponenter er modulerne i en graf de samme som modulerne i dens komplement , og moduler kan "indlejres" - ét modul kan være sin egen delmængde af et andet. Bemærk, at toppunktet i en graf er et modul, ligesom singleton-sæt og det tomme sæt . De kaldes trivielle moduler . Grafen kan have andre moduler eller ej. En graf kaldes simpel , hvis alle dens moduler er trivielle.
På trods af forskellene bevarer moduler den ønskede egenskab for forbundne komponenter, hvilket er, at mange egenskaber af subgrafen genereret af en tilsluttet komponent er uafhængige af resten af grafen. Et lignende fænomen observeres for subgrafer genereret af moduler.
Grafmoduler er derfor af stor algoritmisk interesse. Et sæt indlejrede moduler, som modulær ekspansion er et eksempel på, kan bruges til at opnå en rekursiv løsning på mange kombinatoriske problemer på grafer, såsom genkendelse og finding af den transitive orientering af sammenlignelighedsgrafer , genkendelse og søgning af permutationsrepræsentationen af permutationsgrafer , genkende om en graf er en kograf , genkende intervalgrafer og finde en intervalrepræsentation for den, definitionen af afstandsnedarvede grafer [1] og til grafvisualisering [2] . De spiller en vigtig rolle i beviset for den perfekte grafsætning [3] .
Til genkendelse af afstandsarvede grafer og cirkelgrafer er en yderligere generalisering af modulær dekomponering, kaldet split dekomponering [1] , særlig nyttig .
For at undgå tvetydigheden af ovenstående definition giver vi følgende formelle definition af moduler. . er et modul af en graf, hvis:
, og alle singletons for er moduler, og de kaldes trivielle moduler . En graf er enkel , hvis alle dens moduler er trivielle. Forbindelseskomponenter i en graf eller deres komplementer er også moduler af en graf .
er et stærkt grafmodul , hvis det ikke (delvist) overlapper noget andet grafmodul — grafmodulet er enten , eller , eller .
Hvis og er usammenhængende moduler, så er det let at se, at enten er ethvert medlem nabo til ethvert element af , eller intet medlem støder op til noget medlem af . Således er alle elementer i to ikke-skærende moduler enten tilstødende eller ikke tilstødende . Der er ingen mellemtilstand mellem disse to yderpunkter.
I lyset af dette er modulære dekomponeringer , hvor hver dekomponeringsklasse er et modul, af særlig interesse. Antag, at det er en modulær nedbrydning. Da partitionsklasserne ikke skærer hinanden, danner deres naboskab en ny graf, kvotientgrafen , hvis hjørner er termerne . Det vil sige, at hvert toppunkt er et modul af grafen G, og nærheden af disse moduler definerer kanterne .
I figuren nedenfor er top 1, top 2 til 4, top 5, top 6 og 7 og top 8 til 11 modulære. I diagrammet øverst til højre viser kanterne mellem disse sæt kvotienterne givet ved den givne nedbrydning, mens kanterne inden for sættene viser de tilsvarende faktorer.
Partitioner og er trivielle modulære partitioner . er en graf med ét hjørne, mens . Antag, at det er et ikke-trivielt modul. Så er et-element-undersættet også en ikke-triviel modulær partition . Således indebærer eksistensen af ikke -trivielle moduler eksistensen af ikke-trivielle modulpartitioner. Generelt kan de fleste eller alle medlemmer være ikke-trivielle moduler.
Hvis er en ikke-triviel modulær partition, så er en kompakt repræsentation af alle kanter, der ender i forskellige partitionsklasser . For hver undergraf kaldes partitionsklasse genereret af en faktor, og den giver en repræsentation af alle kanter med begge ender i . Således kan kanterne af en graf rekonstrueres, hvis kvotientgrafen og dens faktorer er kendt. Udtrykket simpel graf kommer fra det faktum, at en simpel graf kun har trivielle kvotienter og faktorer.
Hvis er en multiplikator af modulo-kvotienten , kan det vise sig, at der kan faktoriseres rekursivt og kvotienter. Hvert niveau af rekursion giver en kvotient. Som basistilfælde har grafen ét toppunkt. Grafen kan rekonstrueres ved at rekonstruere faktorer nedefra, vende partitioneringstrinene ved at samle faktorer med kvotienter på hvert niveau.
I figuren nedenfor er en sådan rekursiv dekomponering repræsenteret som et træ, hvilket afspejler en af måderne til rekursivt at faktorisere de indledende modulære dekomponeringsfaktorer i mindre modulære partitioner.
Metoden til rekursivt at opdele en graf i faktorer og kvotienter er muligvis ikke den eneste. (For eksempel er alle delmængder af hjørnerne af en komplet graf moduler, hvilket betyder, at der er mange forskellige måder at dekomponere den graf på rekursivt.) Nogle måder at dekomponere kan være mere nyttige end andre.
Heldigvis er der en rekursiv dekomponering af en graf, der implicit repræsenterer alle de måder, hvorpå den kan dekomponeres. Dette er modularisering. Det er i sig selv en måde at rekursivt dekomponere en graf i kvotienter, men den inkluderer alle de andre. Nedbrydningen vist i figuren nedenfor er en speciel dekomponering af den givne graf.
Nedenfor er en central observation til forståelse af modulær nedbrydning:
Hvis er et modul af grafen og er en delmængde af , så er et modul hvis og kun hvis det er et modul af .
Gallai [4] definerede en modulær dekomponering rekursivt på en graf med mange hjørner som følger:
Det endelige træ har et enkelt sæt af grafhjørner som blade, som er basissagen. Et sæt grafhjørner er et modul, hvis og kun hvis det er en træknude eller en forening af efterkommere af en seriel eller parallel knude. Dette tildeler implicit alle modulære udvidelser til toppen . I denne forstand "koncentrerer det modulære nedbrydningstræ i sig selv" alle andre måder at rekursivt dekomponere en graf til delvise.
Datastrukturen til at repræsentere et modulært nedbrydningstræ skal understøtte operationer, der tager en node som input og returnerer det sæt af grafspidser , som knudepunktet repræsenterer. Den oplagte måde at gøre dette på er at tildele hver knude en liste over hjørner i grafen , som knudepunktet repræsenterer. Givet en pointer til en knude, kan det sæt af grafspidser , som knudepunktet repræsenterer, hentes i tide . En sådan struktur vil dog i værste fald kræve hukommelse .
Hukommelsesalternativet opnås ved at repræsentere det modulære nedbrydningstræ med en hvilken som helst standard rodfæstet træbaseret datastruktur og mærke hvert blad med det grafiske toppunkt , det repræsenterer. Sættet repræsenteret af den interne node er defineret af sættet af etiketter af dets efterkommerblade. Det er velkendt, at ethvert rodfæstet træ med blade højst har indre noder. Du kan bruge dybde-først-søgning startende ved for at få etiketter af efterkommerblade på et tidspunkt .
Hver knude er et sæt af hjørner i grafen , og hvis det er en intern knude, er sættet af efterkommere en opdeling , hvor hver opdelt klasse er et modul. Derfor genererer de en kvotient i . Hjørnerne i denne kvotient er elementer af , så de kan repræsenteres ved at etablere kanter mellem børnene af . Hvis og er to led og , , Så og er tilstødende i hvis og kun hvis og er tilstødende i kvotienten. For ethvert par af grafhjørner bestemmes dette af de private efterkommere af den største fælles forfader og i det modulære nedbrydningstræ. Derfor giver en modulær dekomponering mærket som kvotienter på denne måde en komplet repræsentation af grafen .
Mange kombinatoriske problemer kan løses på en graf ved at løse dem separat for hver kvotient. For eksempel er en sammenlignelighedsgraf, hvis og kun hvis hver af disse kvotienter er en sammenlignelighedsgraf [4] [5] . For at afgøre, om en graf er en sammenlignelighedsgraf, er det derfor tilstrækkeligt at kontrollere dette for hver af dens kvotienter. Faktisk, for at finde den transitive orientering af en sammenlignelighedsgraf, er det tilstrækkeligt at finde den transitive orientering af hver af dens kvotienter i den modulære dekomponering [4] [5] . Et lignende fænomen findes for permutationsgrafer [6] , intervalgrafer [7] , perfekte grafer og andre klasser af grafer. Nogle vigtige kombinatoriske optimeringsproblemer på grafer kan løses ved hjælp af lignende strategier [8] .
Kografer er grafer, der kun har parallelle eller sekventielle noder i deres modulære nedbrydningstræ.
Den første polynomiske tidsalgoritme til beregning af det modulære nedbrydningstræ af en graf blev offentliggjort i 1972 [9] , og lineære tidsalgoritmer er nu tilgængelige [6] [10] .
Modulær dekomponering af rettede grafer kan opnås i lineær tid [11] .
Med nogle få enkle undtagelser har enhver graf med en ikke-triviel modulær dekomponering også en skæv partition [12] .