Ohraničující objem - Bounding volume

3D model s ohraničovacím rámečkem nakresleným přerušovanými čarami.

v počítačová grafika a výpočetní geometrie, a mezní objem pro sadu objektů je uzavřený svazek, který zcela obsahuje svaz předmětů v sadě. Ohraničující svazky se používají ke zlepšení efektivity geometrických operací pomocí jednoduchých svazků, které obsahují složitější objekty. Za normálních okolností mají jednodušší svazky jednodušší způsoby test na překrytí.

Ohraničující svazek pro sadu objektů je také ohraničujícím svazkem pro jeden objekt skládající se z jejich sjednocení a naopak. Proto je možné omezit popis na případ jediného objektu, o kterém se předpokládá, že je neprázdný a ohraničený (konečný).

Použití

Hraniční svazky se nejčastěji používají k urychlení určitých druhů testů.

v sledování paprsku, jsou použity mezní objemy zkoušky průnikem paprskem a v mnoha vykreslovací algoritmy, jsou používány pro prohlížení frustum testy. Pokud paprsek nebo zorné pole neprotínají hraniční objem, nemohou protínat objekt obsažený v něm, což umožňuje triviální odmítnutí. Podobně, pokud komolý komůrk obsahuje celý ohraničující objem, může to být obsah triviálně přijato bez dalších testů. Tyto testy průniku vytvářejí seznam objektů, které musí být „zobrazeny“ (vykresleny; rastrovaný ).

v Detekce kolize, když se dva ohraničující svazky neprotínají, obsažené objekty nemohou kolidovat.

Testování proti ohraničujícímu svazku je obvykle mnohem rychlejší než testování proti samotnému objektu z důvodu jednodušší geometrie vázaného svazku. Je to proto, že „objekt“ se obvykle skládá z polygonů nebo datových struktur, které jsou redukovány na polygonální aproximace. V obou případech je výpočetně nehospodárné testovat každý polygon proti objemu pohledu, pokud objekt není viditelný. (Objekty na obrazovce musí být na obrazovku „připnuty“, bez ohledu na to, zda jsou jejich povrchy skutečně viditelné.)

Chcete-li získat ohraničující objemy složitých objektů, běžným způsobem je rozdělit objekty / scénu pomocí a graf scény nebo konkrétněji a hierarchie vázaného svazku, jako např. Stromy OBB. Základní myšlenkou je uspořádat scénu ve stromové struktuře, kde kořen zahrnuje celou scénu a každý list obsahuje menší podčást.

Běžné typy

Volba typu ohraničujícího svazku pro danou aplikaci je dána řadou faktorů: výpočetní náklady na výpočet ohraničujícího svazku pro objekt, náklady na jeho aktualizaci v aplikacích, ve kterých se objekty mohou pohybovat nebo měnit tvar nebo velikost , náklady na určení křižovatek a požadovaná přesnost testu křižovatky. Přesnost testu průniku souvisí s množstvím prostoru v ohraničujícím svazku, který není spojen s ohraničeným objektem, tzv. prázdný prostor. Sofistikované ohraničující svazky obecně umožňují méně prázdného prostoru, ale jsou výpočetně nákladnější. Je běžné používat několik typů ve spojení, například levný pro rychlý, ale hrubý test ve spojení s přesnějším, ale také dražším typem.

Všechny typy zde ošetřené dávají konvexní mezní objemy. Pokud je o ohraničeném objektu známo, že je konvexní, nejedná se o omezení. Pokud jsou vyžadovány nekonvexní ohraničující svazky, je třeba je reprezentovat jako spojení řady konvexních ohraničujících svazků. Testy křižovatky se bohužel stávají rychle dražšími, protože hraniční krabice jsou čím dál propracovanější.

A ohraničující rámeček je kvádr, nebo ve 2-D a obdélník obsahující objekt. v dynamická simulace, ohraničující rámečky jsou upřednostňovány před jinými tvary ohraničujícího objemu, jako je ohraničující koule nebo válce pro objekty, které mají zhruba tvar kvádru, když musí být test průniku docela přesný. Výhoda je zřejmá například u předmětů, které spočívají na jiných, jako je například auto odpočívající na zemi: ohraničující koule by ukázala, že by se auto mohlo protínat se zemí, což by pak bylo nutné odmítnout nákladnějším testem skutečného modelu automobilu; ohraničující rámeček okamžitě ukazuje, že se auto neprotíná s vozovkou, což šetří nákladnější test.

V mnoha aplikacích je ohraničující rámeček zarovnán s osami souřadného systému a je pak znám jako ohraničující rámeček zarovnaný na osu (AABB). K odlišení obecného případu od AABB se někdy nazývá libovolné ohraničující pole an orientovaný ohraničovací rámeček (OBB), nebo OOBB když je existující objekt lokální souřadnicový systém se používá. AABB je mnohem jednodušší testovat průnik než OBB, ale mají tu nevýhodu, že když se model otáčí, nelze s ním jednoduše otáčet, ale je třeba jej přepočítat.

A ohraničující kapsle je zametl kouli (tj. objem, který koule vezme, když se pohybuje po úsečce) obsahující objekt. Kapsle mohou být reprezentovány poloměrem tažené koule a segmentem, přes který je koule tažena). Má vlastnosti podobné válci, ale je jednodušší, protože test průniku je jednodušší. Kapsle a další objekt se protínají, pokud je vzdálenost mezi definujícím segmentem kapsle a některým znakem druhého objektu menší než poloměr kapsle. Například dvě kapsle se protínají, pokud je vzdálenost mezi segmenty kapslí menší než součet jejich poloměrů. To platí pro libovolně rotované kapsle, a proto jsou v praxi přitažlivější než válce.

A ohraničující válec je válec obsahující objekt. Ve většině aplikací je osa válce zarovnána se svislým směrem scény. Válce jsou vhodné pro 3D objekty, které se mohou otáčet pouze kolem svislé osy, ale ne kolem ostatních os, a jsou jinak omezeny v pohybu pouze pomocí posunu. Dva válce zarovnané se svislou osou se protínají, když se současně protínají jejich projekce na vertikální ose - což jsou dva úsečkové segmenty - a také jejich projekce na vodorovné rovině - dva kruhové disky. Oba lze snadno otestovat. v videohry, ohraničující válce se často používají jako ohraničující objemy pro lidi stojící vzpřímeně.

A ohraničující elipsoid je elipsoid obsahující objekt. Elipsoidy obvykle poskytují těsnější tvar než koule. Křižovatky s elipsoidy se provádí změnou měřítka druhého objektu podél hlavní osy elipsoidu o částku rovnající se multiplikativní inverzní poloměrů elipsoidu, čímž se zmenší problém protnutí zmenšeného objektu s a jednotková koule. Je třeba dbát na to, aby se předešlo problémům, pokud se zavede použité měřítko překroutit. Zkosení může v určitých případech znemožnit použití elipsoidů, například kolize mezi dvěma libovolnými elipsoidy.

A ohraničující sféra je koule obsahující objekt. Ve 2D grafice je to a kruh. Ohraničující koule jsou reprezentovány středem a poloměrem. Velmi rychle testují vzájemnou kolizi: dvě koule se protínají, když vzdálenost mezi jejich středy nepřesahuje součet jejich poloměrů. Díky tomu jsou ohraničující koule vhodné pro objekty, které se mohou pohybovat v libovolném počtu dimenzí.

A ohraničující deska je objem, který vyčnívá do určité míry na osu, a lze jej považovat za desku ohraničenou mezi dvěma rovinami. Ohraničující rámeček je průsečík ortogonálně orientovaných ohraničujících desek. K urychlení byly použity ohraničující desky sledování paprsku[1]

A ohraničující trojúhelník v 2-D je docela užitečné pro zrychlení oříznutí nebo testu viditelnosti B-Spline křivky. Vidět „Algoritmy oříznutí kruhu a B-Splines“ pod předmětem Clipping (počítačová grafika) pro příklad použití.

A konvexní obal je nejmenší konvexní svazek obsahující objekt. Pokud je objekt spojením konečné množiny bodů, jeho konvexní trup je mnohostěn.

A diskrétně orientovaný polytop (DOP) zobecňuje ohraničující rámeček. K-DOP je booleovský průsečík rozsahů k Pokyny. Tak, a k-DOP je booleovská křižovatka k ohraničující desky a je konvexní polytop obsahující objekt (ve 2-D a polygon; v 3-D a mnohostěn ). 2-D obdélník je speciální případ 2-DOP a 3-D box je speciální případ 3-DOP. Obecně platí, že osy DOP nemusí být ortogonální a může existovat více os než rozměrů prostoru. Například 3-D rámeček, který je zkosený na všech hranách a rozích, lze zkonstruovat jako 13-DOP. Skutečný počet tváří může být méně než 2krát k pokud některé tváře zdegenerují, zmenší se na hranu nebo vrchol.

A minimální ohraničující obdélník nebo MBR - nejméně AABB ve 2-D - se často používá v popisu geografických (nebo „geoprostorových“) datových položek, které slouží jako zjednodušený proxy pro prostorový rozsah datové sady (viz geoprostorová metadata ) pro účely vyhledávání dat (včetně případných prostorových dotazů) a zobrazení. Je také základní součástí R-strom metoda prostorové indexování.

Základní kontroly křižovatky

U některých typů ohraničujícího objemu (OBB a konvexní mnohostěny) je účinnou kontrolou kontrola teorém o oddělovací ose. Myšlenka zde je, že pokud existuje osa, kterou se objekty nepřekrývají, pak se objekty neprotínají. Kontrolované osy jsou obvykle osy základních os pro objemy (jednotkové osy v případě AABB nebo 3 základní osy z každé OBB v případě OBB). Často následuje také kontrola křížových produktů předchozích os (jedna osa od každého objektu).

V případě AABB se z těchto testů stane jednoduchá sada testů překrytí, pokud jde o jednotkové osy. Pro AABB definován M,N proti jedné definované Ó,P neprotínají se, pokud (MX > PX) nebo (ÓX > NX) nebo (My > Py) nebo (Óy > Ny) nebo (Mz > Pz) nebo (Óz > Nz).

AABB lze také promítnout podél osy, například pokud má hrany délky L a je vycentrováno na C, a promítá se podél osy N:
, a nebo , a kde m a n jsou minimální a maximální rozsahy.

OBB je v tomto ohledu podobný, ale je o něco složitější. Pro OBB s L a C, jak je uvedeno výše, as , J, a K. jako základní osy OBB, pak:

Pro rozsahy m,n a Ó,p lze říci, že se neprotínají, pokud m > p nebo Ó > n. Takže promítnutím rozsahů 2 OBB podél os I, J a K každého OBB a kontrolou neprotínání je možné detekovat neprotínání. Dodatečnou kontrolou podél křížových produktů těchto os (I0× I1, Já0× J.1, ...) lze si být jistější, že průnik je nemožný.

Tento koncept určování neprotínajícího se průřezu pomocí osy se také vztahuje na konvexní mnohostěny, avšak místo základních os se používají normály každé polyhedrální plochy a rozsahy jsou založeny na minimálních a maximálních bodových produktech každého vrcholu proti osám. Tento popis předpokládá, že se kontroly provádějí ve světovém prostoru.

Křižovatka dvou k-DOP lze vypočítat velmi podobně jako AABB: pro každou orientaci stačí zkontrolovat dva odpovídající intervaly dvou DOP. Stejně jako je DOP zobecněním AABB, je test průniku zevšeobecněním testu překrytí AABB. Složitost testu překrytí dvou DOP je uvnitř Ó(k). To však předpokládá, že oba DOP jsou uvedeny s ohledem na stejnou sadu orientací. Pokud se jeden z nich otočí, již to není pravda. V takovém případě jeden relativně snadný způsob, jak zkontrolovat dva DOP pro průnik je uzavřít otočený, , dalším nejmenším uzavírajícím DOP který je orientován s ohledem na orientace prvního DOP . Postup je o něco složitější, ale nakonec se rovná násobení složitosti maticového vektoru Ó(k) také.[2]

Viz také

Reference

  1. ^ POV-Ray Dokumentace[1]
  2. ^ G. Zachmann: Rychlá detekce kolize dynamicky zarovnanými stromy DOP. Proc. of IEEE Virtual Reality Annual International Symposium (VRAIS, now IEEE VR), 1998, pp. 90-97, DOI 10.1109 / VRAIS.1998.658428, ISBN  0-8186-8362-7 URL: http://cgvr.informatik.uni-bremen.de/papers/vrais98/vrais98.pdf

externí odkazy