Presentation is loading. Please wait.

Presentation is loading. Please wait.

CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Sampling Theorem & Antialiasing April 15, 2003.

Similar presentations


Presentation on theme: "CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Sampling Theorem & Antialiasing April 15, 2003."— Presentation transcript:

1 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Sampling Theorem & Antialiasing April 15, 2003

2 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Today’s Short Film NVIDIA Demo

3 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Part I: Sampling Theorem

4 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Example of Aliasing in Computer Graphics

5 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Examples of Aliasing in 1D See Figure 14.2 (p.394) of Watt’s book for other examples.

6 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Sampling 1D Signal: x  f(x) becomes i  f(i) 2D Image: x, y  f(x, y) –For grayscale image, f(x, y) is the intensity of pixel at (x, y).

7 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Reconstruction If the samples are “dense” enough, then we can recover the original signal. Question is: How dense is enough?

8 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 An Intuition – Using a Single Frequency It’s easy to figure out for a sin wave. What about any signal (usually a mixture of multiple frequencies)? Enter Fourier Transform…

9 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Fourier Transform Can we separate signal into a set of signals of single frequencies? t  

10 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Convolution To start with, image that f(x) is nonzero only in the range of [-a, a]. –Then we only need to consider g(x) in the range of [x-a, x+a] Multiplication in spatial domain results in convolution in frequency domain (and vice versa).

11 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Sampling Spatial domain: multiply with a pulse train. Frequency domain: convolution.

12 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Reconstruction Frequency domain: Spatial domain: convolve with Sinc function

13 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Reconstruction Kernel For perfect reconstruction, we need to convolve with the sinc function. –It’s the Fourier transform of the box function. –It has infinite “support” May be approximated by Gaussian, cubic, or even triangle “tent” function.

14 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Nyquist Limit Nyquist Limit = 2 * max_frequency Undersampling: sampling below the Nyquist Limit.

15 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 An Exercise You have an online photo albums, and you want to show an index page using smaller versions of photos. –Original size is 1600x1200 –Index photo: 200x150 (1/8 of original) How do you create the index photos?

16 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Basis Functions An example: X=[x 1, x 2, …, x n ] U=[u 1, u 2, …, u n ] V=[v 1, v 2, …, v n ] Let X = a*U + b*V, how to find a and b? If U and V are orthogonal, then a and b are the projection of X onto U and V.

17 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Compared to Fourier Transform Consider a continuous signal as a infinite- dimensional vector [ f(  ), f(2  ), f(3  ),….. ] Consider each frequency  a basis, then F(  ) is the projection of f(x) onto that basis. t

18 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 An Intuition for Convolution Does it make sense to you that multiplication in one domain becomes convolution in the other domain? Look at this example: What are the coefficients of P 1 *P 2 ?

19 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Convolution and Splatting Let f(x) be the reconstruction kernel, g(x) is the source, h(x) the target. We are only interested in g(a), g(2a)… and h(b), h(2b)… Two way to evaluate h(b), h(2b), …h(nb) –Use the above equation directly. (Loop over h(b), h(2b), …) –Or we can “splat” g(x)! (Loop over g(a), g(2a), …)

20 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 g(x) h(x) f(x) ?

21 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Part II: Antialiasing

22 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Changes within a Pixel A lot can change within a pixel: –Shading –Edge –Texture Point sampling at the center often produces undesirable result.

23 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Pixel Coverage What should be the pixel colors for these? Can we simply use the covered areas of blue and white? (Hint: convolve with box filter.) Do we have enough data to compute the coverage?

24 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Antialiasing Consider a ray tracer. Is it often impossible to find the partial coverage of an edge. Each ray is a point sample. We may use many samples for each pixel  slower performance.

25 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Antialiasing – Uniform Sampling Also called supersampling Wasteful if not much changes within a pixel.

26 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Filtering How do we reduce NxN supersamples into a pixel? –Average? –More weight near the center? Let’s resort to the sampling theorem.

27 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Reconstruction Frequency domain: Spatial domain:

28 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 A Few Observations In theory, a sample influences not only its pixel, but also every pixels in the image. What does it mean by removing high frequencies?

29 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Antialiasing – Adaptive Sampling Feasible in software, but difficult to implement in hardware. Increase samples only if necessary. But how do we know when is “necessary”? –Check the neighbors.

30 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Antialiasing – Stochastic Sampling Keep the same number of samples per pixel. Replace the aliasing effects with noise that is easier to ignore.

31 CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 EWA for Texture Mapping Paul Heckbert, “Survey of Texture Mapping” IEEE CG&A, Nov. 1986. (Figures)Survey of Texture MappingFigures Green & Heckbert, “Creating Raster Omnimax Images from Multiple Perspective Views Using The Elliptical Weighted Average Filter” IEEE CG&A, 6(6), pp. 21-27, June 1986.Creating Raster Omnimax Images from Multiple Perspective Views Using The Elliptical Weighted Average Filter


Download ppt "CS5520 Image-Based Rendering © Chun-Fa Chang, Spring 2003 Sampling Theorem & Antialiasing April 15, 2003."

Similar presentations


Ads by Google