Minimální algoritmy ohraničujícího pole - Minimum bounding box algorithms
v výpočetní geometrie, nejmenší uzavírací krabička problém je v tom najít orientovaný minimální ohraničující rámeček uzavírající množinu bodů. Je to typ mezní objem. „Nejmenší“ může odkazovat na objem, plocha, obvod, atd. krabice.
Stačí najít nejmenší uzavírací krabici pro konvexní obal předmětných předmětů. Je jednoduché najít nejmenší uzavírací rámeček, který má strany rovnoběžné s osami souřadnic; obtížnou částí problému je určit orientaci krabice.
Dva rozměry
Pro konvexní mnohoúhelník, a lineární čas algoritmus pro minimální plocha uzavírající obdélník je známo. Je založen na pozorování, že strana uzavíracího boxu o minimální ploše musí být kolineární se stranou konvexního mnohoúhelníku.[1] Je možné vyjmenovat boxy tohoto druhu v lineárním čase pomocí volaného přístupu rotační třmeny podle Godfried Toussaint v roce 1983.[2] Stejný přístup je použitelný pro hledání minimální obvodový obdélník.[2]
Tři rozměry
V roce 1985 Joseph O'Rourke zveřejnil algoritmus kubického času k nalezení uzavíracího pole minimálního objemu sady trojrozměrných bodů. O'Rourkeův přístup využívá techniku trojrozměrného rotačního posuvného měřítka a je založen na lemmech charakterizujících minimální uzavírací rámeček:
- Musí existovat dvě sousední plochy uzavíracího boxu s nejmenším objemem, které oba obsahují okraj konvexního trupu množiny bodů. Toto kritérium je splněno jedinou konvexní hranou trupu kolineárně s hranou boxu nebo dvěma odlišnými hranami trupu ležícími v sousedních plochách boxu.
- Ostatní čtyři tváře musí obsahovat pouze bod konvexního trupu. Opět platí, že body, které obsahují, nemusí být odlišné: jediný bod trupu ležící v rohu pole již splňuje tři z těchto čtyř kritérií.
Z toho v nejobecnějším případě, kde na okrajích minimálního uzavíracího rámečku neleží žádné konvexní vrcholy trupu, vyplývá, že mezi plochami boxu musí ležet nejméně 8 konvexních bodů trupu: dva koncové body každé ze dvou hran a další čtyři body, jeden pro každou ze zbývajících čtyř tváří pole. Naopak, pokud se konvexní trup skládá ze 7 nebo méně vrcholů, musí alespoň jeden z nich ležet v okraji minimální uzavírací krabice trupu.[3]
Je také možné přiblížit minimální objem ohraničujícího rámečku na libovolný konstantní faktor větší než jeden, v lineární čas. Algoritmus pro to zahrnuje nalezení aproximace k průměru množiny bodů a použití pole orientovaného k tomuto průměru jako počáteční aproximace k minimálnímu ohraničujícímu poli. Poté je tento počáteční ohraničovací rámeček rozdělen na mřížku s menšími kostkami a body mřížky poblíž hranice konvexní obal vstupu se používá jako a korzet, malá sada bodů, jejichž optimální ohraničovací rámeček se blíží optimálnímu ohraničujícímu rámečku původního vstupu. Nakonec je použit O'Rourkeův algoritmus k nalezení přesného optimálního ohraničujícího rámečku této koresety.[4]
K dispozici je implementace algoritmu Matlab.[5]
Minimální uzavírací rámeček pravidelný čtyřstěn je kostka, s délkou strany 1 /√2 to čtyřstěn; například pravidelný čtyřstěn s délkou strany √2 zapadá do a jednotková kostka, přičemž vrcholy čtyřstěnu leží na vrcholech (0,0,0), (0,1,1), (1,0,1) a (1,1,0) kostky jednotky.[6]
Viz také
Reference
- ^ Freeman, H.; Shapira, R. (1975), "Určení obdélníku zapouzdřujícího minimální plochu pro libovolnou uzavřenou křivku", Komunikace ACM, 18: 409–413, doi:10.1145/360881.360919, PAN 0375828.
- ^ A b Toussaint, G. T (1983), "Řešení geometrických problémů s rotujícími třmeny" (PDF), Proc. MELECON '83, Atény.
- ^ O'Rourke, Josephe (1985), "Hledání minimálních uzavíracích krabic", International Journal of Computer and Information Sciences, 14 (3): 183–199, doi:10.1007 / BF00991005, PAN 0824371.
- ^ Barequet, Gill; Har-Peled, Sariel (2001), „Efektivní aproximace ohraničovacího rámečku minimálního objemu bodu nastaveného ve třech rozměrech“, Journal of Algorithms, 38 (1): 91–109, doi:10.1006 / jagm.2000.1127, PAN 1810433.
- ^ Melchior, Samuel (2018). "Implementace algoritmu ohraničovacího boxu minimálního objemu v Matlabu"..
- ^ O'Rourke (1985), Obr. 1, s. 186.