Chamtivé zbarvení - Greedy coloring

Dvě chamtivé barvy stejné korunový graf pomocí různých vrcholných objednávek. Správný příklad zobecňuje na dvoubarevné grafy s n vrcholy, kde chamtivý algoritmus utrácí n/2 barvy.

Ve studii o zbarvení grafu problémy v matematika a počítačová věda, a chamtivé zbarvení nebo postupné zbarvení[1] je zbarvení vrcholy a graf tvořený a chamtivý algoritmus který bere v úvahu vrcholy grafu v pořadí a každému vrcholu přiřadí jeho první dostupné barva. Chamtivá barviva lze nalézt v lineárním čase, ale obecně nepoužívají minimální možný počet barev.

Různé možnosti posloupnosti vrcholů obvykle vytvoří různá zbarvení daného grafu, takže hodně studia chamtivých barev se zabývalo hledáním dobrého uspořádání. Vždy existuje uspořádání, které produkuje optimální zbarvení, ale i když takové uspořádání lze najít pro mnoho speciálních tříd grafů, je těžké je obecně najít. Běžně používané strategie pro řazení vrcholů zahrnují umístění vrcholů vyšších stupňů dříve než vrcholů nižších stupňů nebo výběr vrcholů s menším počtem dostupných barev, než u méně omezených vrcholů.

Varianty chamtivého zbarvení vyberte barvy v online způsobem, aniž byste věděli o struktuře nebarvené části grafu, nebo zvolte jiné barvy, než jsou první dostupné, abyste snížili celkový počet barev. Na plánování a byly použity algoritmy chamtivého zbarvení přidělení registru problémy, analýza kombinačních her a důkazy o dalších matematických výsledcích včetně Brooksova věta o vztahu mezi zbarvením a stupněm. Mezi další pojmy v teorii grafů odvozené od chamtivých barev patří Zelené číslo grafu (největší počet barev, které lze najít chamtivým zbarvením) a dobře vybarvené grafy, grafy, u nichž všechna chamtivá barvení používají stejný počet barev.

Algoritmus

Chamtivé zbarvení pro dané uspořádání vrcholů lze vypočítat pomocí algoritmus který běží dovnitř lineární čas. Algoritmus zpracovává vrcholy v daném pořadí a každému z nich při zpracování přiřazuje barvu. Barvy mohou být reprezentovány čísly a každému vrcholu je dána barva s nejmenší číslo, které ještě není použito jedním z jeho sousedů. Chcete-li najít nejmenší dostupnou barvu, můžete pomocí pole spočítat počet sousedů každé barvy (nebo alternativně reprezentovat sadu barev sousedů) a poté skenováním pole vyhledat index své první nuly.[2]

v Krajta lze algoritmus vyjádřit jako:

def first_available(color_list):    "" "Vrátit nejmenší nezáporné celé číslo, které není v daném seznamu barev." ""    color_set = soubor(color_list)    počet = 0    zatímco Skutečný:        -li počet ne v color_set:            vrátit se počet        počet += 1        def chamtivý_barva(G, objednat):    "" "Najděte chamtivé zbarvení G v daném pořadí.    Reprezentace G se předpokládá jako https://www.python.org/doc/essays/graphs/    umožňující iteraci sousedů uzlu / vrcholu pomocí „for w in G [node]“.    Návratová hodnota je slovník mapující vrcholy na jejich barvy. "" "    barva = diktát()    pro uzel v objednat:        used_neighbour_colors = [barva[nbr] pro nbr v G[uzel]                                 -li nbr v barva]        barva[uzel] = first_available(used_neighbour_colors)    vrátit se barva

The first_available podprogram trvá čas úměrný délce jeho seznamu argumentů, protože provádí dvě smyčky, jednu přes samotný seznam a jednu přes seznam počtů, které mají stejnou délku. Času pro celkový algoritmus zbarvení dominují volání tohoto podprogramu. Každá hrana v grafu přispívá pouze k jednomu z těchto hovorů, koncovému bodu hrany, který je později v pořadí vrcholů. Součet délek argumentů tedy uvádí first_availablea celkový čas pro algoritmus jsou úměrné počtu hran v grafu.[2]

Alternativní algoritmus produkující stejné zbarvení,[3] je vybrat sady vrcholů s každou barvou po jedné. V této metodě každá barevná třída je vybráno skenováním vrcholů v daném pořadí. Když toto skenování narazí na nezbarvený vrchol který nemá žádného souseda , dodává na . Takto, se stává maximální nezávislá množina mezi vrcholy, kterým ještě nebyly přiřazeny menší barvy. Algoritmus tímto způsobem opakovaně vyhledává barevné třídy, dokud nejsou vybarveny všechny vrcholy. Zahrnuje však provedení více skenů grafu, jednoho skenování pro každou barevnou třídu, místo výše uvedené metody, která používá pouze jeden sken.[4]

Možnost objednání

Různé uspořádání vrcholů grafu může způsobit, že chamtivé zbarvení použije různé počty barev, od optimálního počtu barev až po v některých případech počet barev, který je úměrný počtu vrcholů v grafu. instance, a korunový graf (graf vytvořený ze dvou disjunktní sady z n/2 vrcholy {A1, A2, ...} a {b1, b2, ...} připojením Ai na bj kdykoli ij) může být obzvláště špatným případem pro chamtivé zbarvení. S objednáváním vrcholů A1, b1, A2, b2, ..., použije se chamtivé zbarvení n/2 barvy, jedna barva pro každý pár (Ai, bi). Optimální počet barev pro tento graf je však dvě, jedna barva pro vrcholy Ai a další pro vrcholy bi.[5] Existují také grafy, že s vysokou pravděpodobností náhodně zvolené řazení vrcholů vede k množství barev mnohem větších, než je minimum.[6] Proto je v chamtivém zbarvení důležitý pečlivý výběr pořadí vrcholů.

Dobré objednávky

Vrcholy libovolného grafu lze vždy uspořádat tak, aby chamtivý algoritmus vytvořil optimální zbarvení. Pro dané optimální zbarvení je možné vrcholy řadit podle jejich barev. Když tedy člověk použije chamtivý algoritmus s tímto řádem, je výsledné vybarvení automaticky optimální.[7] Protože však optimální zbarvení grafu je NP-kompletní, jakýkoli dílčí problém, který by umožnil rychlé vyřešení tohoto problému, včetně nalezení optimálního uspořádání pro chamtivé zbarvení, je NP-tvrdé.[8]

v intervalové grafy a chordální grafy, jsou-li vrcholy uspořádány v obráceném pořadí a perfektní objednávka eliminace, pak dřívější sousedé každého vrcholu vytvoří a klika. Tato vlastnost způsobí, že chamtivé zbarvení vytvoří optimální zbarvení, protože nikdy nepoužívá více barev, než je požadováno pro každou z těchto klik. Pořadí eliminace lze nalézt v lineárním čase, pokud existuje.[9]

Silnější je jakékoli dokonalé objednávání eliminace dědičně optimální, což znamená, že je optimální jak pro samotný graf, tak pro všechny jeho indukované podgrafy. The dokonale uspořádatelné grafy (který zahrnuje chordální grafy, srovnatelné grafy, a vzdálenostně dědičné grafy ) jsou definovány jako grafy, které mají dědičně optimální řazení.[10] Rozpoznávání dokonale uspořádatelných grafů je také NP-úplné.[11]

Špatné objednávky

Počet barev produkovaných chamtivým zbarvením pro nejhorší pořadí daného grafu se nazývá jeho Zelené číslo.[12]Stejně jako je obtížné najít dobré pořadí vrcholů pro chamtivé zbarvení, je obtížné najít i špatné uspořádání vrcholů. Pro daný graf je určování NP úplné. G a číslo k, zda existuje uspořádání vrcholů G který způsobí použití chamtivého algoritmu k nebo více barev. To zejména znamená, že je obtížné najít nejhorší objednávku G.[12]

Grafy, pro které je pořadí irelevantní

The dobře vybarvené grafy jsou grafy, u nichž všechna barevná provedení vrcholů produkují stejný počet barev. Tento počet barev se v těchto grafech rovná chromatickému číslu i Grundovu číslu.[12] Zahrnují cographs, což jsou přesně grafy, ve kterých jsou všechny indukované podgrafy jsou dobře vybarvené.[13] Ale je co-NP-kompletní k určení, zda je graf dobře zbarvený.[12]

Pokud náhodný graf je čerpáno z Erdős – Rényiho model s konstantní pravděpodobností zahrnutí každé hrany, pak jakékoli uspořádání vrcholů, které je zvoleno nezávisle na hranách grafu, vede k vybarvení, jehož počet barev se blíží dvojnásobku optimální hodnoty, s vysokou pravděpodobností Zůstává neznámé, zda existuje metoda polynomiálního času pro nalezení výrazně lepšího zabarvení těchto grafů.[3]

Degenerace

Trojúhelníkový hranol a čtvercový antiprism, grafy, jejichž chamtivé barvy využívající pořadí degenerace dávají větší než optimální počet barev

Protože je obtížné najít optimální uspořádání vrcholů, byla použita heuristika, která se pokouší snížit počet barev, aniž by zaručila optimální počet barev. Běžně používaným uspořádáním pro chamtivé zbarvení je výběr vrcholu proti minima stupeň, objednejte podgraf s proti odstraněn rekurzivně a poté umístěte proti poslední v objednávce. Největší stupeň odstraněného vrcholu, se kterým se tento algoritmus setkává, se nazývá zvrhlost grafu, označeno d. V kontextu chamtivého zbarvení se stejná strategie objednávání nazývá také nejmenší poslední objednávka.[14] Toto uspořádání vrcholů a degeneraci lze vypočítat v lineárním čase.[15]Lze jej zobrazit jako vylepšenou verzi dřívější metody řazení vrcholů, největšího prvního řazení, která třídí vrcholy v sestupném pořadí podle jejich stupňů.[16]

Při objednávání degenerace bude chamtivé zbarvení použito nanejvýš d + 1 barvy. Je to proto, že pokud budou zbarveny, každý vrchol bude mít maximálně d již vybarvené sousedy, takže jeden z prvních d + 1 barvy budou pro použití zdarma.[17] Chamtivé zbarvení s uspořádáním degenerace může najít optimální zbarvení pro určité třídy grafů, včetně stromů, pseudolesy a korunové grafy.[18] Markossian, Gasparian & Reed (1996) definovat graf být -dokonalé, pokud, pro a každý indukovaný podgraf z , chromatické číslo se rovná degeneraci plus jedna. U těchto grafů je vždy optimální chamtivý algoritmus s uspořádáním degenerace.[19]Každý -perfektní graf musí být rovnoměrný graf bez děr, protože i cykly mají chromatické číslo dvě a degeneraci dvě, neodpovídající rovnosti v definici -dokonalé grafy. Pokud graf a jeho doplňkový graf jsou oba bez děr, jsou oba -perfektní. Grafy, které jsou oba perfektní grafy a -dokonalé grafy jsou přesně chordální grafy. Na grafech bez rovnoměrných děr obecně se pořadí degenerace přibližuje optimálnímu zbarvení maximálně dvojnásobku optimálního počtu barev; to je jeho přibližný poměr je 2.[20] Na jednotkové diskové grafy jeho přibližný poměr je 3.[21] The trojúhelníkový hranol je nejmenší graf, u kterého jedno z jeho degenerovaných uspořádání vede k neoptimálnímu zabarvení, a čtvercový antiprism je nejmenší graf, který nelze optimálně obarvit pomocí žádného z jeho degeneračních uspořádání.[18]

Adaptivní objednávky

Brélaz (1979) navrhuje strategii, tzv DSatur, pro řazení vrcholů v chamtivém zbarvení, které prokládá konstrukci uspořádání s procesem barvení. Ve své verzi algoritmu chamtivého zbarvení je vybrán další vrchol, který má být zbarven v každém kroku, jako ten s největším počtem odlišných barev v jeho sousedství. V případě vazeb je ze svázaných vrcholů vybrán vrchol maximálního stupně v podgrafu nezbarvených vrcholů. Sledováním sad sousedních barev a jejich kardinality v každém kroku je možné tuto metodu implementovat v lineárním čase.[22]

Tato metoda může najít optimální barviva pro bipartitní grafy,[23] Všechno kaktusové grafy, Všechno grafy kol, všechny grafy na maximálně šesti vrcholech a skoro každý -barevný graf.[24] Ačkoli Lévêque & Maffray (2005) původně tvrdil, že tato metoda najde optimální zbarvení pro Meyniel grafy, později našli protiklad tohoto tvrzení.[25]

Alternativní schémata výběru barev

Je možné definovat varianty algoritmu chamtivého zbarvení, ve kterém jsou vrcholy daného grafu vybarveny v dané sekvenci, ale ve kterých barva vybraná pro každý vrchol nemusí být nutně první dostupnou barvou. Patří mezi ně metody, ve kterých je nezbarvená část grafu algoritmu neznámá, nebo ve kterých je algoritmu dána určitá volnost, aby mohl lépe vybírat barvy než základní chamtivý algoritmus.

Online výběr

Alternativní strategie výběru barev byly studovány v rámci online algoritmy. V online problému s barvením grafů jsou vrcholy grafu prezentovány jeden po druhém v libovolném pořadí podle algoritmu barvení; algoritmus musí zvolit barvu pro každý vrchol, pouze na základě barev a sousedství mezi již zpracovanými vrcholy. V této souvislosti se měří kvalita strategie výběru barev podle ní konkurenční poměr, poměr mezi počtem barev, které používá, a optimálním počtem barev pro daný graf.[26]

Pokud v grafu nejsou uvedena žádná další omezení, je optimální konkurenční poměr jen mírně sublineární.[27] Nicméně pro intervalové grafy, je možný stálý konkurenční poměr,[28] zatímco pro bipartitní grafy a řídké grafy lze dosáhnout logaritmického poměru. Ve skutečnosti pro řídké grafy standardní chamtivá barevná strategie výběru první dostupné barvy dosahuje tohoto konkurenčního poměru a je možné prokázat odpovídající spodní hranici konkurenčního poměru jakéhokoli online algoritmu zbarvení.[26]

Šetrné zbarvení

A šetrné zbarvení, pro dané uspořádání grafů a vrcholů bylo definováno jako zbarvení vytvořené chamtivým algoritmem, který vybarví vrcholy v daném pořadí, a zavádí novou barvu pouze tehdy, když všechny předchozí barvy sousedí s daným vrcholem, ale mohou si vybrat jakou barvu použít (místo toho, aby vždy vybrala nejmenší), když je schopna znovu použít existující barvu. The objednané chromatické číslo je nejmenší počet barev, které lze získat pro dané pořadí tímto způsobem, a ochromatické číslo je největší uspořádané barevné číslo mezi všemi barvami vrcholů daného grafu. Přes svou odlišnou definici se ochromatické číslo vždy rovná Grundovu číslu.[29]

Aplikace

Protože je to rychlé a v mnoha případech lze použít jen málo barev, lze chamtivé vybarvení použít v aplikacích, kde je potřeba dobré, ale ne optimální vybarvení grafu. Jednou z prvních aplikací chamtivého algoritmu bylo řešení problémů, jako je plánování kurzů, při kterém musí být skupině úkolů přiřazena určitá sada časových úseků, aby se zabránilo přiřazení nekompatibilních úkolů stejnému časovému úseku.[4]Může být také použit v překladače pro přidělení registru tím, že ji použijeme na graf, jehož vrcholy představují hodnoty, které mají být přiřazeny registrům a jejichž hrany představují konflikty mezi dvěma hodnotami, které nelze přiřadit ke stejnému registru.[30] V mnoha případech jsou tyto interferenční grafy chordální grafy, umožňující chamtivé zbarvení k vytvoření optimálního přiřazení registru.[31]

v kombinatorická teorie her, pro nestranná hra uveden v explicitní formě jako směrovaný acyklický graf jehož vrcholy představují herní pozice a jejichž hrany představují platné tahy z jedné polohy do druhé, chamtivý algoritmus zbarvení (pomocí reverzu topologické uspořádání grafu) vypočítá nim-hodnota každé pozice. Tyto hodnoty lze použít k určení optimální hry v jakékoli jednotlivé hře disjunktivní částka her.[32]

Pro graf maximálního stupně Δ, použije se maximálně jakékoli chamtivé zbarvení Δ + 1 barvy. Brooksova věta uvádí, že až na dvě výjimky (kliky a liché cykly ) nejvíce Δ barvy jsou potřeba. Jeden důkaz Brooksovy věty zahrnuje nalezení uspořádání vrcholů, ve kterém první dva vrcholy sousedí s posledním vrcholem, ale ne sousedí navzájem a každý vrchol kromě posledního má alespoň jednoho pozdějšího souseda. Pro objednávání s touto vlastností používá algoritmus chamtivého zbarvení nanejvýš Δ barvy.[33]

Poznámky

Reference