Filtrování textur - Texture filtering

v počítačová grafika, filtrování textur nebo vyhlazování textury je metoda použitá k určení barvy textury pro a textura mapována pixel pomocí barev blízkých texels (pixely textury). Existují dvě hlavní kategorie filtrování textur, filtrování zvětšení a filtrování minifikace.[1] V závislosti na situaci je filtrování textur buď typem rekonstrukční filtr kde řídký data je interpolován, aby vyplnil mezery (zvětšení) nebo typ Anti aliasing (AA), kde vzorky textury existují s vyšší frekvencí, než je požadováno pro frekvenci vzorků potřebnou pro vyplnění textury (minifikace). Zjednodušeně řečeno, filtrování popisuje, jak se textury aplikují v mnoha různých tvarech, velikostech, úhlech a měřítcích. V závislosti na zvoleném algoritmu filtru bude výsledek zobrazovat různé stupně rozmazání, detailů, prostorového aliasingu, dočasného aliasingu a blokování. Filtrování lze v závislosti na okolnostech provádět v softwaru (například softwarový vykreslovací balíček) nebo v hardwaru v reálném čase nebo GPU zrychlené vykreslování nebo ve směsi obou. Pro většinu běžných interaktivních grafických aplikací se moderní filtrování textur provádí pomocí vyhrazený hardware který optimalizuje přístup do paměti prostřednictvím ukládání do mezipaměti a předběžné načtení a implementuje výběr algoritmů dostupných uživateli a vývojáři.

Existuje mnoho metod filtrování textur, které způsobují různé kompromisy výpočetní složitost, šířka pásma paměti a kvalita obrazu.

Potřeba filtrování

Během procesu mapování textury pro libovolný 3D povrch, a vyhledávání textur probíhá zjistit, kde na texturu spadá každý střed pixelu. U polygonálních povrchů mapovaných texturou složených z trojúhelníků typických pro většinu povrchů ve 3D hrách a filmech každý pixel (nebo vzorek podřízeného pixelu ) této plochy bude spojeno s některými trojúhelníky a sadou barycentrické souřadnice, které se používají k zajištění polohy v rámci textury. Taková poloha nemusí ležet dokonale na „pixelové mřížce“, což vyžaduje určitou funkci, která by tyto případy zohlednila. Jinými slovy, protože texturovaný povrch může být v libovolné vzdálenosti a orientaci vzhledem k divákovi, jeden pixel obvykle neodpovídá přímo jednomu texelu. K určení nejlepší barvy pixelu je třeba použít nějakou formu filtrování. Nedostatečné nebo nesprávné filtrování se v obrázku zobrazí jako artefakty (chyby v obrázku), například „blokovitost“, jaggies nebo třpytivé.

Mezi pixelem a texely / texely, které na obrazovce představuje, mohou být různé typy korespondence. Ty závisí na poloze texturovaného povrchu vzhledem k divákovi a v každém případě jsou zapotřebí různé formy filtrování. S ohledem na čtvercovou strukturu mapovanou na čtvercový povrch na světě je v určité vzdálenosti sledování velikost jednoho pixelu obrazovky přesně stejná jako jeden texel. Bližší než to jsou texely větší než pixely obrazovky a je třeba je vhodně zvětšit - proces známý jako zvětšení textury. Dále je každý texel menší než pixel, takže jeden pixel pokrývá více texelů. V tomto případě je třeba vybrat vhodnou barvu na základě krytých texelů pomocí minifikace textury. Grafika API jako OpenGL umožnit programátorovi nastavit různé možnosti filtrů pro zvětšení a zmenšení.[1]

Všimněte si, že i v případě, že pixely a texely mají přesně stejnou velikost, jeden pixel nemusí nutně odpovídat přesně jednomu texelu. Může být špatně zarovnán nebo otočen a může pokrývat části až čtyř sousedních texelů. Proto je stále nutná nějaká forma filtrování.

Mipmapping

Mipmapping je standardní technika používaná k uložení některých filtračních prací potřebných během minifikace textury.[2] Je také velmi přínosné pro soudržnost mezipaměti - bez toho vzor přístupu do paměti během vzorkování ze vzdálených textur bude vykazovat extrémně špatnou lokalitu, což nepříznivě ovlivní výkon, i když neprovádí filtrování.

Během zvětšování textury je počet texelů, které je třeba vyhledat u libovolného pixelu, vždy čtyři nebo méně; během minifikace se však texturovaný polygon potenciálně posune dále celá struktura může spadnout do jediného pixelu. To by vyžadovalo čtení Všechno jejich textů a kombinace jejich hodnot ke správnému určení barvy pixelu, což je neúměrně nákladná operace. Mipmapping tomu předchází tím, že předfiltruje texturu a uloží ji v menších velikostech až na jeden pixel. Když se texturovaný povrch posune dále, přepíná se aplikovaná textura na předfiltrovanou menší velikost. Různé velikosti mipmapy se označují jako „úrovně“, přičemž úroveň 0 je největší velikostí (používá se nejblíže divákovi) a rostoucí úrovně se používají při zvětšování vzdáleností.

Filtrační metody

V této části jsou uvedeny nejběžnější metody filtrování textur ve vzestupném pořadí výpočtových nákladů a kvality obrazu.

Interpolace nejbližších sousedů

Interpolace nejbližších sousedů je nejjednodušší a nejhrubší metoda filtrování - pro barvu pixelu jednoduše používá barvu texelu nejblíže středu pixelu. I když je to jednoduché, výsledkem je velké množství artefaktů - „blokování“ textury během zvětšení,[3] a aliasing a třpyt během minifikace.[4] Tato metoda je během zvětšování rychlá, ale během minifikace se krok v paměti stává libovolně velkým a často může být méně efektivní než mapování MIP kvůli nedostatku prostorově koherentního přístupu k texturám a opětovnému použití mezipaměti.[5]

Nejbližší soused s mipmappingem

Tato metoda stále používá interpolaci nejbližších sousedů, ale přidává mipmapping - nejdříve se zvolí nejbližší úroveň mipmap podle vzdálenosti, poté se vzorkuje nejbližší střed texelu, aby se získala barva pixelu. Tím se během minifikace významně sníží aliasing a třpyt, ale nevyloučí se úplně. Tímto způsobem zlepšuje přístup do texturové paměti a opětovné použití mezipaměti pomocí vyhnutí se libovolně velkým přístupovým krokům v texturové paměti během rastrování. To nepomáhá s blokací během zvětšování, protože každý zvětšený texel se bude stále jevit jako velký obdélník.

Lineární filtrování mipmap

Méně běžně používané, OpenGL a další API podporují vzorkování nejbližších sousedů z jednotlivých mipmap, zatímco lineárně interpolují dvě nejbližší mipmapy relevantní pro vzorek.

Bilineární filtrování

Bilineární filtrování je dalším krokem nahoru. V této metodě jsou vzorkovány čtyři nejbližší texely ke středu pixelu (na nejbližší úrovni mipmapy) a jejich barvy jsou kombinovány vážený průměr podle vzdálenosti.[6] Tím se odstraní „blokovitost“ pozorovaná během zvětšení, protože nyní dochází k plynulému přechodu barevných změn z jednoho texelu na druhý, místo náhlého skoku, když střed pixelu překročí hranici texelu.[7] Bilineární filtrování pro filtrování zvětšení je běžné. Když se používá pro minifikaci, často se používá s mipmappingem; ačkoli to může být použito bez, to by trpělo stejnými problémy s aliasingem a třpytkami jako filtrování nejbližšího souseda, když by bylo příliš minifikováno. Pro skromné ​​poměry minifikace jej však lze použít jako levný supersample vážené textury s hardwarovou akcelerací.

Trilineární filtrování

Trilineární filtrování je lékem na běžný artefakt, který lze vidět na bilineárně filtrovaných obrázcích mipmap: náhlá a velmi znatelná změna kvality na hranicích, kde se vykreslovací modul přepíná z jedné úrovně mipmap na druhou. Trilineární filtrování to řeší provedením vyhledávání textur a bilineárního filtrování na dva nejbližší úrovně mipmap (jedna vyšší a jedna nižší kvalita) a poté lineárně interpolovat výsledky.[8] Výsledkem je plynulé zhoršení kvality textury, jak se zvyšuje vzdálenost od diváka, spíše než řada náhlých poklesů. Samozřejmě, blíže než úroveň 0 je k dispozici pouze jedna úroveň mipmap a algoritmus se vrátí k bilineárnímu filtrování.

Anizotropní filtrování

Anizotropní filtrování je nejkvalitnější filtrování, jaké je k dispozici v současném spotřebitelském 3D grafické karty. Jednodušší „izotropní“ techniky používají pouze čtvercové mipmapy, které jsou poté interpolovány pomocí bi– nebo trilineárního filtrování. (Izotropní znamená stejný ve všech směrech, a proto se používá k popisu systému, ve kterém jsou všechny mapy spíše čtverce než obdélníky nebo jiné čtyřúhelníky.)

Když je povrch ve velkém úhlu vzhledem k fotoaparátu, nebude výplňová plocha pro texturu přibližně čtvercová. Zvažte běžný případ podlahy ve hře: oblast výplně je mnohem širší než vysoká. V tomto případě se žádná ze čtvercových map nehodí. Výsledkem je rozmazání a / nebo třpyt, v závislosti na tom, jak je zvoleno přizpůsobení. Anisotropní filtrování to napraví vzorkováním textury jako ne-čtvercového tvaru. Cílem je odebrat vzorek textury, aby odpovídal pixelové stopě promítnuté do prostoru textury, a taková stopa není vždy osově zarovnaná s texturou. Dále, když se zabýváme teorií vzorků, pixel není malý čtverec[9] proto jeho stopa nebude promítnutým čtvercem. Sestava stopy v texturním prostoru vzorkuje určitou aproximaci vypočítané funkce promítaného pixelu v texturním prostoru, ale podrobnosti jsou často přibližné,[10] vysoce proprietární a pronikavý do názorů na teorii vzorků. Koncepčně je cílem odebrat správnější anizotropní vzorek vhodné orientace, aby nedocházelo ke konfliktu mezi aliasingem na jedné ose a rozmazáním na druhé, když se projektovaná velikost liší.

V anizotropních implementacích může filtrování obsahovat stejné filtrační algoritmy, které se používají k filtrování čtvercových map tradičního mipmappingu během konstrukce přechodného nebo konečného výsledku.

Procento Bližší filtrování

Hloubka založená Stínové mapování může použít zajímavý filtr procentuálního přiblížení (PCF) s hloubkově mapovanými texturami, který rozšiřuje vnímání druhů filtrů textur, které by mohly být použity. V PCF a hloubková mapa scény se vykresluje ze světelného zdroje. Během následného vykreslování scény se tato hloubková mapa poté promítá zpět do scény z polohy světla a provede se srovnání mezi projektivní hloubkovou souřadnicí a získanou hloubkou vzorku textury. Projektivní souřadnicí bude hloubka obrazových bodů scény od světla, ale získaná hloubka z hloubkové mapy bude představovat hloubku scény podél tohoto promítaného směru. Tímto způsobem může být pro vykreslený pixel provedeno určení viditelnosti pro světlo a tedy osvětlení světlem. Tato operace texturování je tedy booleovský test, zda je pixel osvětlený, lze však pro daný pixel testovat více vzorků a booleovské výsledky sečíst a zprůměrovat. Tímto způsobem v kombinaci s měnícími se parametry, jako je umístění vzorkovaného texelu a dokonce i umístění promítané mapy hloubkové projekce, lze pro pixel vypočítat průměr po porovnání hloubky nebo procento vzorků blíže, a proto osvětlit. Kriticky je třeba provést součet booleovských výsledků a vygenerování procentuální hodnoty po hloubkovém srovnání projektivní hloubky a načtení vzorku, takže toto srovnání hloubky se stane nedílnou součástí filtru textury. Toto procento lze poté použít k vážení výpočtu osvětlení a poskytnout nejen booleovské osvětlení nebo hodnotu stínu, ale výsledek měkkého stínu penumbry.[11][12] Verze tohoto je podporována v moderním hardwaru, kde je provedeno srovnání a je použit bilineární filtr po booleovském srovnání podle vzdálenosti[13]

Viz také

Reference

  1. ^ A b „Kapitola 9 - Průvodce programováním OpenGL“. Glprogramming.com. 2009-02-13. Filtrování. Citováno 2018-01-14.
  2. ^ Williams, Lance (1983). „Pyramidální parametry“ (PDF). ACM SIGGRAPH Počítačová grafika. 17 (3): 1–11. doi:10.1145/964967.801126. ISSN  0097-8930.
  3. ^ „Game Engine Design: Texture Mapping“ (PDF). uncc.edu. Zvětšení textury.
  4. ^ „Game Engine Design: Texture Mapping“ (PDF). uncc.edu. Minifikace textur.
  5. ^ Hendrik Lensch (29. 11. 2007). „Počítačová grafika: Filtrování textur a teorie vzorkování“ (PDF). Společnost Maxe Plancka. MipMaps. Citováno 2018-01-14.
  6. ^ Markus Hadwiger (09.03.2015). „Přednáška o programování GPU a GPGPU 12: Texturování GPU 2“ (PDF). KAUST. Rekonstrukce textury: Zvětšení.
  7. ^ Markus Hadwiger (09.03.2015). „Přednáška o programování GPU a GPGPU 12: Texturování GPU 2“ (PDF). KAUST. Anti-Aliasing textury: Mapování MIP.
  8. ^ Hendrik Lensch (29. 11. 2007). „Počítačová grafika: Filtrování textur a teorie vzorkování“ (PDF). Společnost Maxe Plancka. MipMapping II. Citováno 2018-01-14.
  9. ^ Alvy Ray Smith (1995-07-17). „Pixel není malý čtverec! (A voxel není malá kostka) - technická poznámka 6“ (PDF). cs.princeton.edu. Citováno 2018-01-14.
  10. ^ Hendrik Lensch (29. 11. 2007). „Počítačová grafika: Filtrování textur a teorie vzorkování“ (PDF). Společnost Maxe Plancka. Anizotropní filtrování. Citováno 2018-01-14.
  11. ^ Reeves, William T .; Salesin, David H .; Cook, Robert L. (01.08.1987). „Vykreslování vyhlazených stínů pomocí hloubkových map“ (PDF). ACM SIGGRAPH Počítačová grafika. Sdružení pro výpočetní techniku ​​(ACM). 21 (4): 283–291. doi:10.1145/37402.37435. ISSN  0097-8930.
  12. ^ Randima Fernando (02.07.2008). „Procenta blíž bližší měkké stíny“ (PDF). NVIDIA Corporation. Citováno 2018-01-14.
  13. ^ „Specifikace WebGL WEBGL_depth_texture Khronos Ratified Extension“. Khronos.org. 2014-07-15. Citováno 2018-01-14.