Delaunayova triangulace - Delaunay triangulation

Delaunayova triangulace v rovině s uvedenými kruhy

v matematika a výpočetní geometrie, a Delaunayova triangulace (také známý jako Deloneova triangulace) pro danou sadu P z diskrétní body v letadle je a triangulace DT (P) tak, že nemá smysl P je uvnitř obvod ze všech trojúhelník v DT (P). Delaunayovy triangulace maximalizují minimální úhel všech úhlů trojúhelníků v triangulaci; mají tendenci se vyhýbat pramene trojúhelníky. Triangulace je pojmenována po Boris Delaunay za práci na toto téma z roku 1934.[1]

Pro množinu bodů na stejné linii neexistuje Delaunayova triangulace (pro tento případ je pojem triangulace zdegenerovaný). Pro čtyři nebo více bodů ve stejné kružnici (např. Vrcholy obdélníku) není Delaunayova triangulace jedinečná: každá ze dvou možných triangulací, které rozdělují čtyřúhelník do dvou trojúhelníků splňuje „Delaunayovu podmínku“, tj. požadavek, aby oblouky všech trojúhelníků měly prázdné vnitřky.

Když vezmeme v úvahu ohraničené koule, pojem Delaunayovy triangulace se rozšíří na tři a vyšší dimenze. Zobecnění je možné metriky jiný než Euklidovská vzdálenost. V těchto případech však není zaručeno, že Delaunayova triangulace bude existovat nebo že bude jedinečná.

Vztah s Voronoiho diagramem

Obvody v Delaunayově triangulaci.
Delaunayova triangulace se všemi circumcircles a jejich středy (červeně).
Spojení triangulátorů s oběžníky dává Voronoiův diagram.
Spojením středů kruhovitých kruhů vznikne Voronoiho diagram (v červené).

Delaunay triangulace a oddělený bodová sada P v obecná pozice odpovídá duální graf z Voronoiho diagram pro P.v cirkumcentry of Delaunay triangles are the vertices of the Voronoi diagram. V 2D případě jsou Voronoi vrcholy spojeny pomocí hran, které lze odvodit ze sousedních vztahů Delaunayových trojúhelníků: Pokud dva trojúhelníky sdílejí hranu v Delaunayově triangulaci, jejich obvodové mají být spojeny s hranou v Voronoi teselace.

Zvláštní případy, kdy tento vztah neplatí nebo je nejednoznačný, zahrnují případy jako:

  • Tři nebo více kolineární body, kde jsou circumcircles nekonečné poloměry.
  • Čtyři nebo více bodů na dokonalé kružnici, kde je triangulace nejednoznačná a všechny circumcenters jsou triviálně identické.
  • Okraje Voronoiho diagramu směřující do nekonečna nejsou definovány tímto vztahem v případě konečné množiny P. Pokud Delaunay triangulace se vypočítá pomocí Algoritmus Bowyer-Watson potom by měly být ignorovány circumcenters trojúhelníků majících společný vrchol s "super" trojúhelníkem. Hrany směřující do nekonečna začínají od circumcenteru a jsou kolmé ke společnému okraji mezi udržovaným a ignorovaným trojúhelníkem.

d-dimenzionální Delaunay

Pro sadu P bodů v (d-dimenzionální) Euklidovský prostor, a Delaunayova triangulace je triangulace DT (P) tak, že nemá smysl P je uvnitř cirkus-hypersféra ze všech d-simplexní v DT (P). Je známo[1] že existuje jedinečná Delaunayova triangulace pro P -li P je sada bodů v obecná pozice; tj. afinní trup P je d-dimenzionální a žádná sada d + 2 body P ležet na hranici koule, jejíž vnitřek se neprotíná P.

Problém nalezení Delaunayovy triangulace množiny bodů v d-dimenzionální Euklidovský prostor lze převést na problém hledání konvexní obal množiny bodů v (d + 1) -dimenzionální prostor. Toho lze dosáhnout uvedením každého bodu p zvláštní souřadnice rovnající se |p|2, čímž se z něj stal hyperparaboloid (toto se nazývá „zvedání“); vezmeme spodní stranu konvexního trupu (protože horní koncovka směřuje vzhůru od původu a musí být zlikvidována); a mapování zpět na d-dimenzionální prostor odstraněním poslední souřadnice. Protože konvexní trup je jedinečný, tak je i triangulace za předpokladu, že všechny aspekty konvexního trupu jsou jednoduchosti. K neoficiálním fazetám dochází, pouze když d + 2 z původních bodů leží na stejném místě d-hypersféra, tj. body nejsou v obecné poloze. [2]

Vlastnosti

Ukázkové kroky
Každý snímek animace ukazuje Delaunayovu triangulaci čtyř bodů. V polovině převrácení triangulační hrany ukazuje, že Delaunayova triangulace maximalizuje minimální úhel, nikoli délku hrany trojúhelníků.

Nechat n být počet bodů a d počet rozměrů.

  • Spojením všech jednoduchostí v triangulaci je konvexní trup bodů.
  • Delaunayova triangulace obsahuje Ó(nd / 2⌉) jednoduchosti.[3]
  • V letadle (d = 2), pokud existují b vrcholy na konvexním trupu, pak libovolná triangulace bodů má maximálně 2n − 2 − b trojúhelníky plus jedna vnější plocha (viz Eulerova charakteristika ).
  • Pokud jsou body rozděleny podle a Poissonův proces v rovině s konstantní intenzitou má každý vrchol v průměru šest okolních trojúhelníků. Obecněji pro stejný proces v d rozměrů je průměrný počet sousedů konstantní pouze v závislosti na d.[4]
  • V rovině Delaunayova triangulace maximalizuje minimální úhel. Ve srovnání s jakoukoli jinou triangulací bodů je nejmenší úhel v Delaunayově triangulaci alespoň tak velký jako nejmenší úhel v jakékoli jiné. Delaunayova triangulace však nemusí nutně minimalizovat maximální úhel.[5] Delaunayova triangulace také nemusí nutně minimalizovat délku okrajů.
  • Kruh popisující jakýkoli Delaunayův trojúhelník neobsahuje ve svém vnitřku žádné další vstupní body.
  • Pokud kruh procházející dvěma vstupními body neobsahuje ve svém vnitřku žádné další vstupní body, pak je segment spojující dva body hranou Delaunayovy triangulace daných bodů.
  • Každý trojúhelník Delaunayovy triangulace sady bodů v d-dimenzionální mezery odpovídají fazetě konvexní obal projekce bodů na a (d + 1) -dimenzionální paraboloid a naopak.
  • Nejbližší soused b do jakéhokoli bodu p je na hraně bp v Delaunayově triangulaci od graf nejbližšího souseda je podgraf Delaunayovy triangulace.
  • Delaunayova triangulace je a geometrický klíč: V letadle (d = 2), nejkratší cesta mezi dvěma vrcholy, podél Delaunayových hran, je známa jako ne delší než násobek euklidovské vzdálenosti mezi nimi.[6]

Vizuální definice Delaunay: převrácení

Z výše uvedených vlastností vyplývá důležitá vlastnost: Při pohledu na dva trojúhelníky ABD a BCD se společnou hranou BD (viz obrázky), je-li součet úhlů α a γ menší nebo roven 180 °, splňují trojúhelníky podmínku Delaunay .

Toto je důležitá vlastnost, protože umožňuje použití a převrácení technika. Pokud dva trojúhelníky nesplňují podmínku Delaunay, přepnutím společné hrany BD pro společnou hranu AC vzniknou dva trojúhelníky, které splňují podmínku Delaunay:

Tato operace se nazývá a převrátita lze je zobecnit na tři a vyšší dimenze.[7]

Algoritmy

Potřebujeme robustní a rychlý způsob, jak zjistit, zda má smysl D leží v obvodu A, B, C

Mnoho algoritmů pro výpočet Delaunayových triangulací se spoléhá na rychlé operace pro zjišťování, kdy je bod v obvodu kruhu trojúhelníku, a efektivní datovou strukturu pro ukládání trojúhelníků a hran. Ve dvou dimenzích, jeden způsob, jak zjistit, zda bod D leží v obvodu A, B, C je vyhodnotit určující:[8]

Když A, B a C jsou seřazeny v a proti směru hodinových ručiček řádu je tento determinant pozitivní právě tehdy D leží uvnitř circumcircle.

Flipové algoritmy

Jak již bylo zmíněno výše, pokud trojúhelník není Delaunay, můžeme převrátit jeden z jeho okrajů. To vede k přímému algoritmu: zkonstruujte libovolnou triangulaci bodů a poté překlopte hrany, dokud žádný trojúhelník není Delaunay. Bohužel to může trvat Ω (n2) převrácení okraje.[9] I když lze tento algoritmus zobecnit na tři a vyšší dimenze, jeho konvergence není v těchto případech zaručena, protože je podmíněna propojením podkladu flip graf: tento graf je spojen pro dvourozměrné sady bodů, ale ve vyšších dimenzích může být odpojen.[7]

Přírůstkové

Nejpřímějším způsobem, jak efektivně vypočítat Delaunayovu triangulaci, je opakovaně přidávat jeden vrchol najednou a retriangulovat postižené části grafu. Když vrchol proti přidáme, rozdělíme na tři trojúhelník, který obsahuje proti, pak použijeme flipový algoritmus. Hotovo, bude to trvat O (n) čas: prohledáme všechny trojúhelníky, abychom našli ten, který obsahuje proti, pak potenciálně odklopíme každý trojúhelník. Pak je celková doba běhu O (n2).

Pokud vložíme vrcholy v náhodném pořadí, ukáže se (poněkud složitým důkazem), že každé vložení převrátí v průměru pouze trojúhelníky O (1) - i když někdy převrátí mnohem více.[10]To stále ponechává čas na umístění bodu ke zlepšení. Můžeme ukládat historii provedených rozdělení a převrácení: každý trojúhelník ukládá ukazatel na dva nebo tři trojúhelníky, které jej nahradily. Chcete-li najít trojúhelník, který obsahuje proti, začínáme u kořenového trojúhelníku a sledujeme ukazatel, který ukazuje na trojúhelník, který obsahuje proti, dokud nenajdeme trojúhelník, který ještě nebyl nahrazen. V průměru to také zabere O (log n) čas. Ve všech vrcholech to pak trvá O (n log n) čas.[11] Zatímco se tato technika rozšiřuje do vyšší dimenze (jak dokazují Edelsbrunner a Shah[12]), doba běhu může být v dimenzi exponenciální, i když je konečná Delaunayova triangulace malá.

The Algoritmus Bowyer-Watson poskytuje další přístup pro přírůstkovou konstrukci. Poskytuje alternativu k převrácení hrany pro výpočet Delaunayových trojúhelníků obsahujících nově vložený vrchol.

Bohužel algoritmy založené na převrácení jsou obecně těžko paralelizovatelné, protože přidání určitého bodu (např. Středu kola vozu) může vést až k O (n) po sobě jdoucí převrácení. Blelloch et al.[13] navrhla další verzi přírůstkového algoritmu založeného na rip-and-tent, která je praktická a vysoce paralelizovaná s polylogaritmickým rozpětí.

Rozděl a panuj

A algoritmus rozděl a panuj pro triangulace ve dvou dimenzích vyvinuli Lee a Schachter a vylepšili o Guibas a Stolfi[14] a později Dwyer. V tomto algoritmu jeden rekurzivně nakreslí čáru, aby rozdělil vrcholy na dvě sady. Pro každou sadu je vypočítána Delaunayova triangulace a poté jsou dvě sady sloučeny podél dělicí čáry. Pomocí některých chytrých triků lze operaci sloučení provést v čase O (n), takže celková doba provozu je O (n logn).[15]

U určitých typů množin bodů, jako je jednotné náhodné rozdělení, lze inteligentním výběrem dělících čar očekávaný čas zkrátit na O (n log logn) při zachování nejhoršího výkonu.

Rozdělte a dobýt paradigma k provedení triangulace v d dimenze je uvedena v „DeWall: Rychlé rozdělení a dobývání Delaunayova triangulačního algoritmu v E.d„P. Cignoni, C. Montani, R. Scopigno.[16]

Ukázalo se, že algoritmus rozdělení a dobývání je nejrychlejší technikou generování DT.[17][18]

Sweephull

Sweephull[19] je hybridní technika pro 2D Delaunayovu triangulaci, která využívá radiálně se šířící tažný trup a převrácený algoritmus. Tažený trup je vytvořen postupně iterací radiálně seřazené sady 2D bodů a spojením trojúhelníků s viditelnou částí konvexního trupu, což dává nepřekrývající se triangulaci. Tímto způsobem lze postavit konvexní trup, pokud pořadí bodů zaručuje, že žádný bod nespadne do trojúhelníku. Radiální třídění by však mělo minimalizovat převrácení tím, že je vysoce Delaunay. To je pak spárováno s finálním krokem převrácení iterativního trojúhelníku.

Aplikace

The Euklidovský minimální kostra množiny bodů je podmnožina Delaunayovy triangulace stejných bodů,[20] a to lze využít k efektivnímu výpočtu.

Pro modelování terénu nebo jiných objektů, kterým byla dána sada vzorových bodů, poskytuje Delaunayova triangulace pěknou sadu trojúhelníků, které lze v modelu použít jako polygony. Zejména Delaunayova triangulace se vyhýbá úzkým trojúhelníkům (protože mají ve srovnání s jejich oblastí velké kroužky). Vidět trojúhelníková nepravidelná síť.

Delaunayovy triangulace lze použít ke stanovení hustoty nebo intenzity vzorkování bodů pomocí Delaunay odhad tessellation pole (DTFE).

Delaunayova triangulace náhodné množiny 100 bodů v rovině.

Delaunayovy triangulace jsou často zvyklé generovat sítě pro prostorově diskrétní řešitele, jako je Metoda konečných prvků a metoda konečných objemů simulace fyziky z důvodu záruky úhlu a protože byly vyvinuty algoritmy rychlé triangulace. Typicky je doména, která má být propojena, specifikována jako hrubá zjednodušený komplex; aby byla síť numericky stabilní, musí být vylepšena, například pomocí Ruppertův algoritmus.

Rostoucí popularita Metoda konečných prvků a metoda hraničních prvků techniky zvyšuje motivaci ke zlepšování automatických algoritmů záběru. Všechny tyto algoritmy však mohou vytvářet zkreslené a dokonce nepoužitelné prvky mřížky. Naštěstí existuje několik technik, které mohou využít existující síť a zlepšit její kvalitu. Například vyhlazení (označované také jako zjemnění sítě) je jedna taková metoda, která přemisťuje umístění uzlů tak, aby se minimalizovalo zkreslení prvku. The metoda roztažené mřížky umožňuje generování pseudo-pravidelných sítí, které splňují Delaunayova kritéria, snadno a rychle v jednom kroku.

Omezená Delaunayova triangulace našel aplikace v plánování cesty v automatizované jízdě [21]

Viz také

Reference

  1. ^ A b Delaunay, Borisi (1934). „Sur la sphère vide“. Bulletin de l'Académie des Sciences de l'URSS, Classe des Sciences Mathématiques et Naturelles. 6: 793–800.
  2. ^ Fukuda, Komei. „Často kladené otázky v polyedrickém výpočtu“. www.cs.mcgill.ca. Citováno 29. října 2018.
  3. ^ Seidel, Raimund (1995). "Věta o horním ohraničení pro polytopy: snadný důkaz jeho asymptotické verze". Výpočetní geometrie. 5 (2): 115–116. doi:10.1016 / 0925-7721 (95) 00013-Y.
  4. ^ Meijering, J. L. (1953), "Plocha rozhraní, délka hrany a počet vrcholů v agregátech krystalů s náhodnou nukleací" (PDF), Výzkumné zprávy společnosti Philips, 8: 270–290, archivovány od originál (PDF) dne 03.03.2017. Jak uvádí Dwyer, Rex A. (1991), „Vysokorozměrné Voronovy diagramy v lineárním očekávaném čase“, Diskrétní a výpočetní geometrie, 6 (4): 343–367, doi:10.1007 / BF02574694, PAN  1098813.
  5. ^ Edelsbrunner, Herbert; Tan, Tiow Seng; Waupotitsch, Roman (1992), „An Ó(n2 logn) časový algoritmus pro triangulaci úhlu minmax " (PDF), Časopis SIAM o vědeckých a statistických výpočtech, 13 (4): 994–1008, CiteSeerX  10.1.1.66.2895, doi:10.1137/0913058, PAN  1166172, archivovány z originál (PDF) dne 09.02.2017, vyvoláno 2017-10-24.
  6. ^ Keil, J. Mark; Gutwin, Carl A. (1992), „Třídy grafů, které se přibližují úplnému euklidovskému grafu“, Diskrétní a výpočetní geometrie, 7 (1): 13–28, doi:10.1007 / BF02187821, PAN  1134449.
  7. ^ A b De Loera, Jesús A.; Rambau, Jörg; Santos, Francisco (2010). Triangulace, struktury pro algoritmy a aplikace. Algoritmy a výpočty v matematice. 25. Springer.
  8. ^ Guibas, Leonidas; Stolfi, Jorge (1985). "Primitiva pro manipulaci s obecnými děleními a výpočet Voronoi". Transakce ACM v grafice. 4 (2): 74–123. doi:10.1145/282918.282923. S2CID  52852815.
  9. ^ Hurtado, F.; M. Noy; J. Urrutia (1999). „Převrácení hran v trojúhelnících“. Diskrétní a výpočetní geometrie. 22 (3): 333–346. doi:10.1007 / PL00009464.
  10. ^ Guibas, Leonidas J.; Knuth, Donald E.; Sharir, Micha (1992). "Náhodná přírůstková konstrukce diagramů Delaunay a Voronoi". Algorithmica. 7 (1–6): 381–413. doi:10.1007 / BF01758770. S2CID  3770886.
  11. ^ de Berg, Mark; Otfried Cheong; Marc van Kreveld; Mark Overmars (2008). Výpočetní geometrie: Algoritmy a aplikace (PDF). Springer-Verlag. ISBN  978-3-540-77973-5. Archivovány od originál (PDF) dne 28. 10. 2009. Citováno 2010-02-23.
  12. ^ Edelsbrunner, Herbert; Shah, Nimish (1996). „Inkrementální topologické převrácení funguje pro pravidelné triangulace“. Algorithmica. 15 (3): 223–241. doi:10.1007 / BF01975867. S2CID  12976796.[mrtvý odkaz ]
  13. ^ Blelloch, Guy; Gu, Yan; Shun, Julian; a Sun, Yihan. Parallelism in Randomized Incremental Algorithms Archivováno 2018-04-25 na Wayback Machine. SPAA 2016. doi: 10.1145 / 2935764.2935766.
  14. ^ „VÝPOČET OMEZENÝCH TRIANGULACÍ ZPOŽDĚNÍ V RÁMCI“. www.geom.uiuc.edu. Archivovány od originál dne 22. září 2017. Citováno 25. dubna 2018.
  15. ^ Leach, G. (červen 1992). "Zlepšení nejhorších optimálních delaunayských triangulačních algoritmů.": 15. CiteSeerX  10.1.1.56.2323. Citovat deník vyžaduje | deník = (Pomoc)
  16. ^ Cignoni, P .; C. Montani; R. Scopigno (1998). „DeWall: Rychlé rozdělení a dobývání Delaunayova triangulačního algoritmu v Ed". Počítačem podporovaný design. 30 (5): 333–341. doi:10.1016 / S0010-4485 (97) 00082-1.
  17. ^ Srovnání sekvenčních delaunayských triangulačních algoritmů „Archivovaná kopie“ (PDF). Archivovány od originál (PDF) dne 08.03.2012. Citováno 2010-08-18.CS1 maint: archivovaná kopie jako titul (odkaz)
  18. ^ „Triangulační algoritmy a datové struktury“. www.cs.cmu.edu. Archivováno z původního dne 10. října 2017. Citováno 25. dubna 2018.
  19. ^ "S-trup" (PDF). s-hull.org. Citováno 25. dubna 2018.
  20. ^ Franz Aurenhammer; Rolf Klein; Der-tsai Lee (26. června 2013). Voronoiovy diagramy a Delaunayovy trojúhelníky. Světová vědecká nakladatelská společnost. str. 197–. ISBN  978-981-4447-65-2.
  21. ^ Sterling J. Anderson; Sisir B. Karumanchi; Karl Iagnemma (5. července 2012). „Plánování a řízení založené na omezeních pro bezpečný, poloautonomní provoz vozidel“ (PDF). Sympozium inteligentních vozidel 2012 IEEE. IEEE. doi:10.1109 / IVS.2012.6232153.

externí odkazy