Sledování paprsku
Z Multimediaexpo.cz
Sledování paprsků (z anglického ray tracing) je metoda renderování (výpočtu a zobrazení) 3D počítačové grafiky; přesněji řečeno metoda globálního osvětlení. Na rozdíl od běžného života, kdy se paprsky pohybují od zdroje, odráží se a lámou, až se nakonec střetnou s okem pozorovatele, zde paprsky vycházejí z kamery. To protože ze zdrojů světla vychází nekonečné množství paprsků a nedalo by se v rozumném čase spočítat, které dopadnou na pixely plátna, přes které se oko dívá. Tuto techniku používají například počítačové programy POV-Ray, Blender, Cinema 4D, OctaneRender, Corona Renderer nebo Redshift.
Obsah |
Historie
Historie sledování paprsku sahá až do období první poloviny 16. století, kdy umělec Albrecht Dürer využíval lanka pro projekci správné perspektivy obrazu. Sledování paprsku popisoval také Isaac Newton v jeho knize Optika.[1]
V roce 2006 společnost NVIDIA přišla s počítačovou architekturou CUDA. Do roku 2016 však bylo sledování paprsku (ray tracing) prakticky nepoužitelné kvůli nedostatečné výkonnosti hardware a jasně převažovala metoda rasterizace.
Když se v roce 2017 začala globálně prosazovat grafická karta – GeForce GTX 1060, všichni fanoušci ray tracingu měli opět smůlu. Museli čekat do konce roku 2018 na grafiku – GeForce RTX 2080 Ti,
která konečně zlepšila výpočetní výkon v reálném čase a umožnila tak širší využití této technologie.
Využívané algoritmy
Ray casting algoritmus
Jedná se o předchůdce klasického rekurzivního ray tracingu. V porovnání s rekurzivním algoritmem je rychlejší, protože využívá čistě jednoduchých geometrických tvarů. Barva světla je počítačově vypočítána, ale již nebere v potaz odraz paprsku na okolní objekty. Tímto je technika velice omezena. Nedovoluje přesné vykreslování odrazů světla, přirozených stínů a refrakcí. Tyto efekty se dříve snažili lidé obejít použitím různých kreativních metod jako jsou vlastní texturové mapy.[2]
Využití této techniky proslavil John Carmack v jeho počítačové hře Wolfenstein 3D (Id Software).[2]
Rekurzivní algoritmus
Rekurzivní algoritmus sledování paprsku navazuje na Ray casting. Potom, co světlo dopadne na povrch, tak algoritmus vypočítá, zda se paprsky nerozdělí na další menší paprsky, které vytvoří odlesk a přirozené stíny.[3]
V dnešní době je nejpoužívanější a pomocí tohoto algoritmu jsme schopní vytvořit fotorealistické obrázky, které perfektně simulují dopad světla, stíny, nebo i hloubku ostrosti fotoaparátu. Kvůli náročnosti výpočtů tento proces trvá značně déle.
Přiblížení, jak algoritmus funguje:
Pro každý pixel v obraze { Vytvoř paprsek mířící z oka skrze pixel roviny, kterou renderuješ Inicializuj NejbližšíT na NEKONEČNO a NejbližšíObjekt na ŽÁDNÝ Pro každý objekt ve scéně { Jestliže paprsek protíná tento objekt { Jestliže je vzdálenost protnutí t menší než NejbližšíT { Nastav NejbližšíT na vzdálenost protnutí t Nastav NejbližšíObjekt na tento objekt } } } Jestliže je NejbližšíObjekt roven ŽÁDNÝ { Vyplň tento pixel barvou pozadí } Jinak { Vyšli stínový paprsek ke každému zdroji světla (zjištění zdali je ve stínu pro difuzní a spekulární složku) Jestliže je povrch objektu odrazivý, vytvoř odražený paprsek (rekurze) Jestliže je povrch objektu průhledný, vytvoř refrakční paprsek (lom světla, rekurze) Použij NejbližšíObjekt a NejbližšíT k výpočtu stínovací funkce (barva objektu) Vyplň tento pixel výslednou barvou stínovací funkce } }
Sledování paprsků v optice
Metoda sledování paprsku (ray tracing) je též využívána k simulaci optických systémů. Výhodou je univerzálnost metody. Metodu je možno použít i k simulaci systémů, jejichž analytický popis je jen přibližný nebo není vůbec možný: nelineární optické prvky, prvky pro rentgenovou optiku, atd. Nevýhodou je vysoká výpočetní náročnost metody.
Limitace Ray tracingu
Přestože technologie sledování paprsku funguje dobře pro vypočítání bodových a směrových světel, nefunguje už tak dobře pro plošné světla. Jedná se o světla, která vyzařují záři po celém svém povrchu. Ray tracing využívá pro zjištění, zda je objekt osvětlený, odrazy stínů. Ty jsou ale pouze jednosměrné. Pro správnou implementaci je nutné využít různé odrazy stínů pro různé body v plošném světle. V praxi se využívá aproximace, která ale nedosahuje tak přesných výsledků.[4]
Dalším problémem je to, že ray tracing nebere v potaz vyzařování světla u objektů, kde se světlo odráží (například u skla).[4]
Reference
- ↑ VINKLER, Marek. Raytracing on GPU [online]. Brno : 2010, [cit. 2022-11-06]. Dostupné online.
- ↑ 2,0 2,1 PEDDIE, Jon. What’s the Difference Between Ray Tracing, Ray Casting, and Ray Charles? [online]. 2016-02-02, [cit. 2022-11-19]. [www.electronicdesign.com/technologies/displays/article/21801219/whats-the-difference-between-ray-tracing-ray-casting-and-ray-charles Dostupné online.]
- ↑ NIKODYM, Tomáš. Ray Tracing Algorithm For Interactive Applications [online]. Praha : 2010, [cit. 2022-11-19]. Dostupné online.
- ↑ 4,0 4,1 Introduction to Computer Graphics, Section 8.1 -- Ray Tracing. math.hws.edu [online]. [cit. 2022-11-23]. Dostupné online.
Související články
Externí odkazy
|
|
Náklady na energie a provoz naší encyklopedie prudce vzrostly. Potřebujeme vaši podporu... Kolik ?? To je na Vás. Náš FIO účet — 2500575897 / 2010 |
---|
Informace o článku.
Článek je převzat z Wikipedie, otevřené encyklopedie, do které přispívají dobrovolníci z celého světa. |