Bilineare Filterung

aus Wikipedia, der freien Enzyklopädie
(Weitergeleitet von Bilineares Filtering)

Die bilineare Filterung oder bilineare Interpolation ist eine Erweiterung der linearen Interpolation, um Zwischenwerte innerhalb eines zweidimensionalen rechteckigen Gitters zu bestimmen. Sie wird häufig als Grafikfilter zur Skalierung von Rastergrafiken und zur Darstellung von Texturen bei gerenderten Bildern verwendet.

Mathematische Beschreibung

Bilineare Interpolation

Es wird angenommen, dass der Wert einer Funktion an einem Punkt bestimmt werden soll. Dieser soll weiterhin von vier fixen Rasterpunkten und umgeben sein. Um den Wert näherungsweise (durch lineare Interpolation) zu bestimmen, wird zunächst in eine festgelegte Richtung (horizontal oder vertikal, hier horizontal) zwischen den Rasterpunkten linear interpoliert. Dabei sind und Stützpunkte zwischen den in horizontaler Richtung liegenden Rasterpunkten.

Nach dem gleichen Verfahren wird anschließend zwischen den Werten dieser beiden Punkte interpoliert.

Sind die Rasterpunkte der Funktion in regelmäßiger Form und gegeben, so reduziert sich die Gleichung zu

Diese Gleichung lässt sich in Matrixschreibweise wie folgt zusammenfassen.

Eine Erweiterung dieses Verfahrens um eine zusätzliche dritte Dimension wird als trilineare Interpolation bezeichnet.

Anwendung in der Computergrafik

Bei bilinearer Filterung werden die der Sample-Mitte am nächsten liegenden vier Farben in jeder Achse (u und v) jeweils linear interpoliert. Dazu werden zunächst die beiden Werte zwischen den oberen und den unteren Texeln entlang der u-Achse linear interpoliert. Diese beiden Werte werden anschließend entlang der v-Achse linear interpoliert. Diese zweistufige lineare Interpolation gibt der bilinearen Interpolation ihren Namen. Die Anteile sind dabei nur von der Abtastposition abhängig, nicht jedoch von der Größe der Projektion des Pixels in den Texturraum. Dies führt zwar bei einer Minifikation (die Textur wird stark gestaucht) zu Abtastfehlern, weil zu wenige Texel beachtet werden, wirkt jedoch bei einer Maxifikation (die Textur wird stark vergrößert) glättend, da hierbei bei jedem Pixel dieselben vier Nachbartexel betrachtet, jedoch unterschiedlich gewichtet werden. Anschaulich gesprochen werden die Texel stärker gewichtet, deren Mittelpunkt näher an der Sample-Mitte liegt, wobei immer alle vier benachbarten Texel betrachtet werden.

Eine besondere Bedeutung kommt der bilinearen Filterung beim Echtzeitrendering auf modernen Grafikkarten zu. Hierbei ist die bilineare Filterung ein gebräuchliches Verfahren zum Antialiasing von Texturen. Bilineare Interpolatoren lassen sich durch kaskadierte lineare Interpolatoren schaltungstechnisch vergleichsweise einfach realisieren.

Sofern die Textur per Point Sampling skaliert wird, würde man die Texel als kleine Blöcke erkennen, sodass das Resultat sehr „pixelig“ wäre. Dieses Verfahren fand bei alten Computerspielen, deren Grafik rein von der CPU berechnet wurde, statt.

Grafikprogramme bieten in der Regel auch bikubische Filterung an. Dies vergrößert den Rechenaufwand erheblich, aber liefert in vielen Fällen bessere Qualität.

Weitere Filterungen

Weblinks