fbpx
Wikipedia

Trilinear filtering

Trilinear filtering is an extension of the bilinear texture filtering method, which also performs linear interpolation between mipmaps.[1][2]

Bilinear filtering has several weaknesses that make it an unattractive choice in many cases: using it on a full-detail texture when scaling to a very small size causes accuracy problems from missed texels, and compensating for this by using multiple mipmaps throughout the polygon leads to abrupt changes in blurriness, which is most pronounced in polygons that are steeply angled relative to the camera.

To solve this problem, trilinear filtering interpolates between the results of bilinear filtering on the two mipmaps nearest to the detail required for the polygon at the pixel.[3] If the pixel would take up 1/100 of the texture in one direction, trilinear filtering would interpolate between the result of filtering the 128×128 mipmap as y1 with x1 as 128, and the result of filtering on the 64×64 mipmap as y2 with x2 as 64, and then interpolate to x = 100.

The first step in this process is to determine how big in terms of the texture the pixel in question is. There are a few ways to do this, and the ones mentioned here are not necessarily representative of all of them.

  • Use the distance along the texture between the current pixel and the pixel to its right (or left, or above, or below) as the size of the pixel.
  • Use the smallest (or biggest, or average) of the various sizes determined by using the above method.
  • Determine the uv-values of the corners of the pixel, use those to calculate the area of the pixel, and figure out how many pixels of exactly the same size would take up the whole texture.

Once this is done, bilinear filtering is carried out on the two mipmaps with pixel sizes that are immediately larger and smaller than the calculated size of the pixel, and then interpolate between them as normal.

Since it uses both larger and smaller mipmaps, trilinear filtering cannot be used in places where the pixel is smaller than a texel on the original texture, because mipmaps larger than the original texture are not defined. Bilinear filtering still works, and can be used in these situations without worrying too much about abruptness because bilinear and trilinear filtering provide the same result when the pixel size is exactly the same as the size of a texel on the appropriate mipmap.

Trilinear filtering still has weaknesses, because the pixel is still assumed to take up a square area on the texture. In particular, when a texture is at a steep angle compared to the camera, detail can be lost[1] because the pixel actually takes up a narrow but long trapezoid: in the narrow direction, the pixel is getting information from more texels than it actually covers (so details are smeared), and in the long direction the pixel is getting information from fewer texels than it actually covers (so details fall between pixels). To alleviate this, anisotropic ("direction dependent") filtering can be used.[1]

References edit

  1. ^ a b c Wilde, Tyler (13 March 2019). "PC graphics options explained". PC Gamer. Retrieved 3 February 2024.
  2. ^ "Fine-tune your graphics". Maximum PC. August 2004. Retrieved 3 February 2024.
  3. ^ Pulli, Kari; Aarnio, Tomi; Miettinen, Ville; Romeia, Kimmo; Vaarala, Jani (19 November 2007). Mobile 3D Graphics With OpenGL ES and M3G. Elsevier Science. ISBN 978-0-08-055591-1.

See also edit

trilinear, filtering, this, article, needs, additional, citations, verification, please, help, improve, this, article, adding, citations, reliable, sources, unsourced, material, challenged, removed, find, sources, news, newspapers, books, scholar, jstor, febru. This article needs additional citations for verification Please help improve this article by adding citations to reliable sources Unsourced material may be challenged and removed Find sources Trilinear filtering news newspapers books scholar JSTOR February 2024 Learn how and when to remove this template message Trilinear filtering is an extension of the bilinear texture filtering method which also performs linear interpolation between mipmaps 1 2 Bilinear filtering has several weaknesses that make it an unattractive choice in many cases using it on a full detail texture when scaling to a very small size causes accuracy problems from missed texels and compensating for this by using multiple mipmaps throughout the polygon leads to abrupt changes in blurriness which is most pronounced in polygons that are steeply angled relative to the camera To solve this problem trilinear filtering interpolates between the results of bilinear filtering on the two mipmaps nearest to the detail required for the polygon at the pixel 3 If the pixel would take up 1 100 of the texture in one direction trilinear filtering would interpolate between the result of filtering the 128 128 mipmap as y1 with x1 as 128 and the result of filtering on the 64 64 mipmap as y2 with x2 as 64 and then interpolate to x 100 The first step in this process is to determine how big in terms of the texture the pixel in question is There are a few ways to do this and the ones mentioned here are not necessarily representative of all of them Use the distance along the texture between the current pixel and the pixel to its right or left or above or below as the size of the pixel Use the smallest or biggest or average of the various sizes determined by using the above method Determine the uv values of the corners of the pixel use those to calculate the area of the pixel and figure out how many pixels of exactly the same size would take up the whole texture Once this is done bilinear filtering is carried out on the two mipmaps with pixel sizes that are immediately larger and smaller than the calculated size of the pixel and then interpolate between them as normal Since it uses both larger and smaller mipmaps trilinear filtering cannot be used in places where the pixel is smaller than a texel on the original texture because mipmaps larger than the original texture are not defined Bilinear filtering still works and can be used in these situations without worrying too much about abruptness because bilinear and trilinear filtering provide the same result when the pixel size is exactly the same as the size of a texel on the appropriate mipmap Trilinear filtering still has weaknesses because the pixel is still assumed to take up a square area on the texture In particular when a texture is at a steep angle compared to the camera detail can be lost 1 because the pixel actually takes up a narrow but long trapezoid in the narrow direction the pixel is getting information from more texels than it actually covers so details are smeared and in the long direction the pixel is getting information from fewer texels than it actually covers so details fall between pixels To alleviate this anisotropic direction dependent filtering can be used 1 References edit a b c Wilde Tyler 13 March 2019 PC graphics options explained PC Gamer Retrieved 3 February 2024 Fine tune your graphics Maximum PC August 2004 Retrieved 3 February 2024 Pulli Kari Aarnio Tomi Miettinen Ville Romeia Kimmo Vaarala Jani 19 November 2007 Mobile 3D Graphics With OpenGL ES and M3G Elsevier Science ISBN 978 0 08 055591 1 See also editBilinear filtering Anisotropic filtering Trilinear interpolation Lanczos resampling Retrieved from https en wikipedia org w index php title Trilinear filtering amp oldid 1217579153, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.