Zu dieser Karteikarte gibt es einen kompletten Satz an Karteikarten. Kostenlos!
14
How are Light Fields rendered? How can we do this on the GPU?
First, consider bi-linear interpolation. In order to determine the color at a position
lying between four grid samples. Each grid sample at a position
has an influence of
data:image/s3,"s3://crabby-images/43e40/43e40647b4984b9ad4fe8738700cb9dd7bbca630" alt=""
on
.
Given: Light Fielddata:image/s3,"s3://crabby-images/03dc6/03dc658a38b68a41a37b2c586882c5ec8efbe238" alt=""
Let
be the coordinates of the four pixels around
on the camera plane and
the coordinates of the four pixels around
on the object plane.
For each
, we compute an interpolated color value
from the four neighboring samples
on the object plane based on the position
.
Then, we compute a interpolated color value from the
, based on the position
.
Since we do a linear interpolation twice, this is called quad-linear interpolation.
GPU Implementation
Obtaining
coordinates for every pixel
Draw two quads: One for the object plane, one for the camera plane. As a texture, use a smooth color gradient from
lower left to
upper right. The rasterized colors are the
coordinates for every pixel.
Bi-Linear Interpolation on the Object Plane
We get this for free through texture interpolation: For each camera plane pixel, render one quad. As texture coordinates for the quad, use the respective
coordinates at that position.
Quad-Linear Interpolation
Instead of rendering one quad per camera plane pixel, render four quads surrounding the pixel with alpha blending and fade out the contribution towards the outer edges.
data:image/s3,"s3://crabby-images/a0e2a/a0e2a3c0c28c3243b9442b68ac437d09b146c03c" alt=""
data:image/s3,"s3://crabby-images/f95d6/f95d6fcf7f434a979f8428c75667d282687da3e2" alt=""
data:image/s3,"s3://crabby-images/43e40/43e40647b4984b9ad4fe8738700cb9dd7bbca630" alt=""
on
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
Given: Light Field
data:image/s3,"s3://crabby-images/03dc6/03dc658a38b68a41a37b2c586882c5ec8efbe238" alt=""
Let
data:image/s3,"s3://crabby-images/4338e/4338e8bbe85d134f7316137b2f4573caf673dc50" alt=""
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
data:image/s3,"s3://crabby-images/8dbf7/8dbf7e6eade879cfb4acd81f7b6f5cdd5d1b6a36" alt=""
data:image/s3,"s3://crabby-images/6aa22/6aa2213088d56dd44328ee7be4e48a638b199714" alt=""
For each
data:image/s3,"s3://crabby-images/49ddd/49ddd0e352cd2d3c6e789f6411be01f1a8861fe0" alt=""
data:image/s3,"s3://crabby-images/0fea3/0fea3ac8b519fc7529a6e33214d5fe67c62eae06" alt=""
data:image/s3,"s3://crabby-images/8dbf7/8dbf7e6eade879cfb4acd81f7b6f5cdd5d1b6a36" alt=""
data:image/s3,"s3://crabby-images/6aa22/6aa2213088d56dd44328ee7be4e48a638b199714" alt=""
Then, we compute a interpolated color value from the
data:image/s3,"s3://crabby-images/0fea3/0fea3ac8b519fc7529a6e33214d5fe67c62eae06" alt=""
data:image/s3,"s3://crabby-images/a0e2a/a0e2a3c0c28c3243b9442b68ac437d09b146c03c" alt=""
Since we do a linear interpolation twice, this is called quad-linear interpolation.
GPU Implementation
Obtaining
data:image/s3,"s3://crabby-images/3cc17/3cc171d3b4ae6b14f3d805b5d015000b311df3a2" alt=""
Draw two quads: One for the object plane, one for the camera plane. As a texture, use a smooth color gradient from
data:image/s3,"s3://crabby-images/711c1/711c14d9c6e58dcfa9f67300ffbb48409cff1cb3" alt=""
data:image/s3,"s3://crabby-images/b1464/b1464056b84923e6fa7c12883c813c0c70e3ff4f" alt=""
data:image/s3,"s3://crabby-images/38794/38794db6de5332cf1c48f7653e557c6e0960b963" alt=""
Bi-Linear Interpolation on the Object Plane
We get this for free through texture interpolation: For each camera plane pixel, render one quad. As texture coordinates for the quad, use the respective
data:image/s3,"s3://crabby-images/6aa22/6aa2213088d56dd44328ee7be4e48a638b199714" alt=""
Quad-Linear Interpolation
Instead of rendering one quad per camera plane pixel, render four quads surrounding the pixel with alpha blending and fade out the contribution towards the outer edges.
data:image/s3,"s3://crabby-images/c64c7/c64c7f61abb9e2d96a6c69beff1bd79eb8bfc4e8" alt=""
Karteninfo:
Autor: janisborn
Oberthema: Informatik
Thema: Computergrafik
Schule / Uni: RWTH Aachen
Ort: Aachen
Veröffentlicht: 18.05.2022