Mnohoúhelníkový oddíl - Polygon partition

A rozdělit a polygon je sada primitivních jednotek (např. čtverců), které se nepřekrývají a jejichž sjednocení se rovná mnohoúhelníku. A problém s polygonovým oddílem je problém najít oddíl, který je v určitém smyslu minimální, například oddíl s nejmenším počtem jednotek nebo s jednotkami s nejmenší celkovou délkou strany.

Polygonové dělení je důležitou třídou problémů výpočetní geometrie. Existuje mnoho různých problémů s polygonovými oddíly, v závislosti na typu polygonu, který je rozdělen, a na typech jednotek povolených v oddílu.

Termín polygonový rozklad je často používán jako obecný termín, který zahrnuje jak zakrytí, tak rozdělení.[1]

Aplikace

Polygonový rozklad se používá v několika oblastech:[1]

  • Rozpoznávání vzorů techniky extrahují informace z objektu za účelem jejich popisu, identifikace nebo klasifikace. Zavedenou strategií pro rozpoznávání obecného polygonálního objektu je jeho rozložení na jednodušší komponenty, identifikace komponent a jejich vzájemných vztahů a použití těchto informací k určení tvaru objektu.
  • v VLSI zpracování dat uměleckých děl, rozvržení jsou reprezentována jako polygony a jedním přístupem k přípravě na litografii elektronovým paprskem je rozložení těchto polygonových oblastí na základní postavy. Polygonní rozklad se také používá v procesu rozdělení směrovací oblasti na kanály.
  • v výpočetní geometrie „Algoritmy pro řešení problémů na obecných polygonech jsou často složitější než algoritmy pro omezené typy polygonů, například konvexní nebo hvězdicovité. The problém se zahrnutím bodu je jeden příklad. Strategií řešení některých z těchto typů problémů na obecných polygonech je rozložit polygon na jednoduché součásti, vyřešit problém na každé součásti pomocí specializovaného algoritmu a poté zkombinovat dílčí řešení.
  • Mezi další aplikace patří komprese dat, databázové systémy, zpracování obrazu a počítačová grafika.

Rozdělení mnohoúhelníku na trojúhelníky

Nejvíce studovaným problémem rozdělení polygonů je rozdělení na nejmenší počet trojúhelníků, nazývaných také triangulace. Pro polygon bez děr s vrcholy, lze vypočítat triangulaci v čase . Pro mnohoúhelník s otvory existuje dolní mez .

Souvisejícím problémem je rozdělení na trojúhelníky s minimální celkovou délkou hrany, nazývané také triangulace s minimální hmotností.

Rozdělení polygonu na pseudo-trojúhelníky

Stejné dvě varianty problému byly studovány pro případ, kdy by kusy měly být pseudotriangles - mnohoúhelníky, které mají rád trojúhelníky, mají přesně tři konvexní vrcholy. Varianty jsou: rozdělení na nejmenší počet pseodutriangles a rozdělení na pseudotriangles s minimální celkovou délkou hrany.

Rozdělení přímého mnohoúhelníku na obdélníky

Zvláštní podskupina problémů s polygonovými oddíly vzniká, když je velký polygon a přímočarý polygon (také volal: ortogonální polygon). V tomto případě je nejdůležitějším tvarem součásti, který je třeba vzít v úvahu, obdélník.[1]

Obdélníkové oddíly mají mnoho aplikací. v VLSI je nutné rozložit masky na jednodušší tvary dostupné v litografických generátorech vzorů a podobné problémy s rozkladem masky vznikají také v DNA design microarray. Obdélníkové oddíly se mohou zjednodušit konvoluce operace v zpracování obrazu a lze je použít ke kompresi bitmapové obrázky. Byly použity úzce související problémy s rozkladem matice radiační terapie plánování a obdélníkové oddíly byly také použity k návrhu robota vlastní montáž sekvence.[2]

Je známo několik algoritmů polynomiálního času pro tento problém; vidět [1]:10–13 a [2]:3–5 pro kontrolu.

Problém rozdělení přímého mnohoúhelníku na nejmenší počet čtverce (na rozdíl od libovolných obdélníků) je NP-tvrdé.[3]

Rozdělte mnohoúhelník na lichoběžníky

V systémech zpracování uměleckých děl VLSI je často nutné rozdělit polygonální oblast na minimální počet lichoběžníky, se dvěma vodorovnými stranami. Trojúhelník s vodorovnou stranou je považován za lichoběžník se dvěma vodorovnými stranami, z nichž jedna je zdegenerovaná. Pro polygon bez děr s po stranách lze najít nejmenší takový oddíl včas .[4]

Pokud počet lichoběžníků nemusí být minimální, lze včas najít lichoběžník , jako vedlejší produkt a polygon triangulace algoritmus.[5]

Pokud polygon obsahuje díry, problém je NP-úplný, ale 3-přiblížení lze najít v čase .[4]

Rozdělte mnohoúhelník na konvexní čtyřúhelníky

A čtyřstrana nebo a kvadrangulace je oddíl do čtyřúhelníky.

Vracející se charakteristikou kvadrangulačních problémů je, zda jsou Steinerův bod jsou povoleny, tj. zda je algoritmu povoleno přidávat body, které nejsou vrcholy mnohoúhelníku. Povolení Steinerových bodů může umožnit menší divize, ale pak je mnohem obtížnější zaručit, že divize nalezené algoritmy mají minimální velikost.

Existují algoritmy lineárního času pro kvadrangulace polygonů bez děr se Steinerovými body, ale není zaručeno, že najdou nejmenší oddíl.[6][7]

Rozdělte polygon na m-gons

Zevšeobecněním předchozích problémů je problém rozdělení na polygony, které mají přesně m nebo maximálně m strany. Zde je cílem minimalizovat celkovou délku hrany. Tento problém lze vyřešit v časovém polynomu v n a m.[8][9]

Obecnější tvary součástí

Byly studovány obecnější tvary kusů, včetně: libovolných konvexní polygony, spirála tvary, hvězdné polygony a monotónní polygony. Vidět [1] pro průzkum.

Viz také

Reference

  1. ^ A b C d E F Mark Keil, J. (2000). "Polygonový rozklad". Příručka výpočetní geometrie. 491–518. doi:10.1016 / B978-044482537-7 / 50012-7. ISBN  9780444825377.
  2. ^ A b C Eppstein, David (2010). "Graficko-teoretická řešení problémů s výpočetní geometrií". Graf-teoretické koncepty v informatice. Přednášky z informatiky. 5911. s. 1–16. CiteSeerX  10.1.1.249.5965. doi:10.1007/978-3-642-11409-0_1. ISBN  978-3-642-11408-3.
  3. ^ Realz Slaw. „Dlažba ortogonálního polygonu se čtverci“. Výměna zásobníku CS. Citováno 19. října 2015.
  4. ^ A b C Asano, Takao; Asano, Tetsuo; Imai, Hiroshi (1986). "Rozdělení polygonální oblasti na lichoběžníky". Deník ACM. 33 (2): 290. doi:10.1145/5383.5387. hdl:2433/98478.
  5. ^ Chazelle, Bernard (2007). „Triangulace jednoduchého polygonu v lineárním čase“. Diskrétní a výpočetní geometrie. 6 (3): 485–524. doi:10.1007 / bf02574703.
  6. ^ H. Everett; W. Lenhart; M. Overmars; T. Shermer; J. Urrutia. (1992). "Striktně konvexní čtyřstěnné polygony". Proc. 4. Canad. Konf. Comput. Geom. str. 77–83.
  7. ^ Ramaswami, Suneeta; Ramos, Pedro; Toussaint, Godfried (1998). Msgstr "Převádění triangulací na kvadrangulace". Výpočetní geometrie. 9 (4): 257. doi:10.1016 / s0925-7721 (97) 00019-9.
  8. ^ Lingas, Andrzej; Levcopoulos, Christos; Sack, Jörg (1987). Msgstr "Algoritmy pro minimální délky polygonů". BIT. 27 (4): 474. doi:10.1007 / bf01937272.
  9. ^ Levcopoulos, Christos; Lingas, Andrzej; Pytel, Jörg-R. (1989). "Heuristika pro optimální binární vyhledávací stromy a problémy s triangulací minimální hmotnosti". Teoretická informatika. 66 (2): 181. doi:10.1016/0304-3975(89)90134-5.
  10. ^ Lingas, Andrzej (1982). "Síla nepřímých děr". Automaty, jazyky a programování. Přednášky z informatiky. 140. 369–383. doi:10.1007 / bfb0012784. ISBN  978-3-540-11576-2.