Grafické a fyzikální principy (2023)
Warning
Tato je stará verze otázky. Nová verze: Fyzikální principy ve vývoji her.
Note
Příprava a vývoj scény, grayboxing, zástupné modely (placeholders). Optimalizace výkonu vykreslování (úrovně detailů, odstřelování objektů, MIP mapy). Využití shaderů pro efekty ve hrách. Sledování paprsků, objekty pro detekci kolizí, fyzika hadrové panenky.
PA010, PA199, PA213, PV255
Příprava a vývoj scény
Section titled “Příprava a vývoj scény”Note
Poznámky o grayboxingu, iterování, modulárním workflow, atd. jsou z přednášky Lukáše Medka v rámci PV255. 1
-
Iterace
Práce v iteracích pomáhá:- udržet konzistenci,
- mít přehled o objemu práce,
- průběžně přídávat obsah a
- šetřit čas.
-
Základní workflow
- Modelování high-poly a low-poly modelů
- Unwrap
- Tvorba textur a materiálů
- Vypečení map (normály, bump, atd.)
- Aplikace shaderu v engine
- Optimalizace
-
Grayboxing
- Rychlý nástřel modelu / scény / prostředí.
- Obrovská časová úspora při tvorbě assetů. Místo jejich finální podoby se používají placeholdery (obvykle šedé krabice).
- Umožňuje implementovat mechaniky bez nutnosti čekat na assety.
- Limituje odpad — nevyužité assety — při změnách nebo škrtech.
-
Modulární workflow
Využití malého množství assetů pro vytvoření rozsáhlého prostředí. Nutná promyšlená preprodukce. 2 -
Modulární textury
Textury aplikovatelné na více modelů. Je potřeba na všechna využití myslet při vytváření textury. -
Placeholders
Zjednodušené / low-poly / koupené / kradené modely nebo šedé / oranžové / libovolné krabice, které jsou v pohodě pro prototyping, ale neměly by být ve finální hře.
Optimizalizace výkonu vykreslování
Section titled “Optimizalizace výkonu vykreslování”-
Level-of-detail (LOD) / úrovně detailů
Čím větší vzdálenost, tím méně detailů. 3Pro každý model máme hierarchii modelů s různým počtem polygonů. V závislosti na vzdálenosti od pozorovatele vybíráme vhodný LOD.

Dají se vytvořit manuálně i automaticky (pomocí algoritmů pro mesh reduction / decimation).
-
Diskrétní LOD
Existuje fixní počet variant meshe, mezi kterými se přepíná diskrétně. Nevýhodou je “popping” efekt. -
Continous LOD
Mezi variantami se nepřepíná “ráz naráz”, ale postupně tak, že v jeden moment jsou vykresly dva LODy přes sebe a blendovány pomocí alpha kanálu. -
Geomorphic LOD
Redukuje popping postupnou “proměnnou” jednoho LODu na druhý odebíráním a přidáváním hran. Generuje approximované mezistavy.Geomorphing by Sirotk

-
Hierarchical LOD
Seskupuje objekty ve scéně do hierarchie a zjednodušuje celé skupiny objektů najednou. Vede k lepšímu výkonu. -
Texture filtering
Popisuje, jakým způsobem se pixely textury (texely) mapují na pixely obrazovky / daného polygonu. 4Součástí problému je potřeba odhadnout, jak velkou plochu polygon zabere na obrazovce.
-
Mipmapy
multum in parvo — mnoho v malém prostoru
V zásadě LOD na texturách. Z velikosti otexturovaného polygonu je LOD . Výsledek je získán interpolací mezi LODy a .
Mimojiné je to tedy přístup k texture filteringu, kdy aproximujeme velikost polygonu pomocí čtverce daného úrovní mipmapy.
Separate color channels of a mipmapped texture by Phorgan1

Tip
Jak je patrné z obrázku výše, chytrým uložením je mipmapovaná textura jen o 33 % větší než původní textura. (Nová má velikost té staré.)
-
Shaderové / GPU optimalizace
Existuje řada nástrojů, které umožňují debugovat a optimalizovat GPU:- V Unity: Rendering Statistics, Frame Debugger
- nVidia Nsight: obecné debuggování GPU
- Intel Graphics Performance Analyzers: obecné debuggování GPU
- RenderDoc: debuggování OpenGL, DirectX a Vulkan
-
Object culling / ostřelování objektů
Nalézání podmnožiny objektů ve scéně, která může být vynechána, aniž by viditelně ovlivnila výsledný obraz. Počítání přesné viditelnosti je příliš náročné, proto se používají aproximace známé jako potentially visible set (PVS). 5 -
Back-face culling
Vykreslování pouze předních stran polygonů. -
View frustum culling
Vykreslování pouze objektů, které jsou v zorném poli kamery. -
Occlusion culling
Vykreslování pouze objektů, které nejsou zakryty jinými objekty.
-
Portal culling
Užitečné, pokud máme statickou scénu, kde jsou některé části viditelné jen z některých jiných částí (např. místnosti v domě). Část dat potřebných pro odstřel tak může být předpočítána.

-
Obecné zásady
- Nevykreslovat co není nutné (zahazovat na CPU, využívat předchozí snímky)
- LODovat
- Batching (Unity) — shlukovat geometrie a vykreslovat naráz
- Instancing — vykreslovat vícero instancí stejného objektu naráz
- Minimalizovat počet materiálů (např. spojováním textur).
- Vypéct všechni nedynamické (statická světla, stíny, atd.)
Využití shaderů pro efekty ve hrách
Section titled “Využití shaderů pro efekty ve hrách”-
Toon / cel shading
Toon shading používá jen několik ruzných “kroků” intezity barev. Cel shading prý přidává kontury, ale zdá se, že ty termíny jsou spíš synonyma. 6 7Cel-shaded Utah Teapot by NicolasSourd

-
Color grading
Využívá se look-up table (LUT) pro jednotnou barevnou korekci. 8 9 -
Marschner Hair
Shader, co používá Pixar pro vlasy a chlupy postavený na výzkumu Steva Marschnera. Má tři složky: odraz (R), průchod skrz (TT), vnitřní odraz (TRT). 8 10 -
Hloubka obrazu / depth of field
Fyzikálně korektní bokeh. Simuluje fotoaparát včetně clony (F-stop), velikosti snímače (full-frame, APS-C, atd.), ohniskové vzdálenosti, počtu lamel, atd. 8
Tip
Circle of Confusion (CoC) je kruh způsobený imperfektním zaostřením. Měřením CoC foťáky určují depth of field. 11
Ray tracing / sledování paprsků
Section titled “Ray tracing / sledování paprsků”Ray tracing jsou techniky, které trasují paprsky světla napříč scénou.
- Jsou pomalejší než empirické modely jako Blinn-Phong,
- Jsou limitované na jeden úhel pohledu (pomineme-li hacky).
- Ray tracing zvládá odrazy, refrakci a další chování světla věrohodněji.
The first bounce of the ray-tracing algorithm schematic by Henrik
-
Path tracing
Monte Carlo technika, kdy pro každý pixel je do scény vysláno množství paprsků. Když paprsek narazí na objekt, je buď absorbován, odražen nebo zlomen — což je zvoleno náhodně.Rozdíl oproti klasickému ray tracingu je právě v oné náhodnosti. Klasický ray tracing počítá všechny odražené i zlomené paprsky, které trasuje ke každému ze světelných zdrojů. Path tracing poskytuje “jen” statistický vzorek z nich.
-
Využití
- Animované filmy
- Vizuální efekty
- Architektonické vizualizace
- Hry
-
Spatial data structure
Datové struktury popisujicí objekty v prostoru. Volba vhodné struktury je klíčová pro efektivitu ray tracingu, ale je fajn i pro všední průchod scénou. 12
-
Bounding volume hierarchy (BVH)
Hierarchická reprezentace scény, díky které průchod scénou zredukován z na ( je počet objektů ve scéně). Dá se stavět top-down nebo bottom-up. 12Chceme od ní dvě věci:
- Rychlý průchod a dotazování na průnik mezi objemy.
- Rychlou kostrukci a aktualizace.
-
Surface Area Heuristic (SAH)
Metrika udávající cenu průchodu BVH. Používá se v řadě různých BVH algoritmů a jejich evaluaci.Mějme následující scénu:

Pravděpodobnost, že paprsek trefí je . Analogicky .
Cena průchodu uzlem BVH je pak:
kde:
- je cena průchodu vnitřním uzlem,
- je cena kontroly průniku,
- je počet trojúhelníků v listu,
Celková cena BVH je pak:
Modrý výraz je konstantní, tmavě červený se snažíme minimalizovat volbou BVH algoritmu.
-
Agglomerative Clustering
Bottom-up metoda, kdy se jednotlivé trojúhelníky postupně shlukují do clusterů. Strom trvá déle postavit, ale je efektivnější ho procházet. -
Morton Codes
Pro efektivní hledání nejbližších bodů se využívá křivek vyplňujících prostor. Jednou takovou je Mortonova Z-křivka.Four iterations of the Z-order curve by David Eppstein
Fyzikální simulace
Section titled “Fyzikální simulace”Important
Renderování založenému na fyzikálních principech se věnuje část otázky Pokročilá počítačová grafika.
-
Rigid body
Aproximace reálného fyzikálního tělesa. Předpokládá uniformní hostotu a neřeší:- deformace objektu,
- aerodynamičnost tvaru.
Nicméně řeší:
- dynamiku (část mechaniky, která se zabývá příčinami pohybu),
- kolize,
- klouby.
-
Soft body
Deformovatelný objekt. -
Fyzikální enginy
- PhysX (Nvidia) — Unity, Unreal Engine.
- Bullet — Blender, Paradox engine.
- Havok
- Box2D
Objekty pro detekci kolizí
Section titled “Objekty pro detekci kolizí”V principu funguje detekce kolizí tak, že v každém kroku fyzikální simulace: 13
- dojde ke kontrole, zda se dva objekty dotýkají — či mají společný průnik,
- pokud ano a kolize jsou pro dané objekty povoleny, dojde k výpočtu kolizních dat (normála, hloubka průniku, atd.),
- ostatní systémy mohou reagovat na kolizi (např. způsobit explozi miny).
-
Fáze
- Broad phase — hledání kandidátů na kolize
- Např. pokud se dotýkají AABB nebo jsou objekty v přibližně stejné oblasti.
- Využívají se struktury pro vyhledávání jako octree, k-D tree, BSP, atd, které je potřeba aktualizovat každé iteraci fyzikální simulace.
- Narrow phase — kontrola zda se kandidáti fakt srazili.
- Broad phase — hledání kandidátů na kolize
-
Sweep and prune
Algoritmus pro broad phase. -
Gilbert-Johnson-Keerthi (GJK)
Algoritmus pro narrow phase. Rozhoduje zda dva konvexní tvary mají společný průnik. -
Primitivní collidery
Výpočty s nimi jsou rychlé.-
krabice (AABB),
-
koule,
-
kapsle,
-
válec.
Primitivní collidery v Unity

-
-
Mesh collider
Neprimitivní collider objekt. Obvykle konvexní obal nějakého meshe. Vypočetně náročné. -
Compound collider
Collider složený z vícero primitivních colliderů. Rychlejší než mesh collider. Použitelný i na nekonvexní objekty. -
Quickhull
Algoritmus pro výpočet konvexního obalu. -
Statické objekty
Terén, budovy, a podobné nehybné objekty. Nepůsobí na něj fyzikální síly, ale fungují jako collidery. Necollidují však vzájemně. Mívají komplexní tvar. -
Dynamické objekty
Působí na ně fyzika. Měly by mít jednodušší collidery. -
Discrete collision detection
Kolize se detekují v každém kroku fyzikální simulace. Výpočetně nenáročné, ale může docházet k “tunelování” objektů skrz jiné objekty. -
Continous collision detection (CCD)
Kolize se detekují v “průběhu pohybu” objektů — pomocí supersamplingu, raycastingu, swept spheres, atd. Výpočetně náročné.
Fyzika hadrové panenky
Section titled “Fyzika hadrové panenky”Specifický pohyb postav bezvědomí. Kombinuje animace a fyziku. Je založená na:
- skeletal systém (rig) — kostra postavy,
- joint restriction — kloubech,
- rozdělení postavy na skupiny rigid bodies,
- springs and dampers — pružiny a tlumiče.
The first “ragdoll falling downstairs” (1997) 14

- Featherstone’s algorithm
Algoritmus pro výpočet dynamiky stromovité struktury propojených článků.
Zdroje
Section titled “Zdroje”-
: Lukáš Medek (CBE), Základní postupy při tvorbě assetů a herního vizuálu ↩
-
Byška, Furmanová, Kozlíková, Trtík: PA010 Intermediate Computer Graphics (podzim 2021) ↩
-
Sochor: PA010 Intermediate Computer Graphics (podzim 2020) ↩
-
https://www.fxguide.com/fxfeatured/pixars-renderman-marschner-hair/ ↩