Skip to main content

A personal annotations of Veach's thesis (22)

Overview idea of Bidirectional path tracing

In forward path tracing method, we don't know where the light comes from, therefore, we sample them to find them. However, light comes from light sources. Therefore, it is natural to distribute light from the light source and then sample the environment to find where is bright. This could be more efficient. How this can be done without biasing is an issue and the paper described it.

There are some cases that forward path tracer hardly handles some paths. For example, a projector projects an image to a wall. Forward path tracer creates paths from a view point and hits the wall, then samples the lens of the projector. Just looking up the light source (the projector) can be done, but, it is difficult to see the image on the wall since such a dense samples must be on the lens without a direct guidance. It's not impossible for forward path tracer, but practically it is hard and mostly we could not see an image.

In this case, the projector projects an image to the wall and sample the wall would be more efficient. This is my understanding of the basic idea of bidirectional path tracing.

Overview idea of Metropolis sampling algorithm

There is a case that bidirectional path tracer also has problems to find some kind of paths. Veach's paper's example is that: ``there are two rooms, one room has a light source, other is dark room that doesn't have any light source. There is a door in-between the rooms, that is almost closed. The camera is in the dark room.'' The light only passes through the gap of the door. To avoid bias, we could not sample the door's gap only. (Is we do that, then there will be a path that can not be detected.) If we can find a nice path once, we should exploit something similar path, but not the same ones. This is the Metropolis method. (Metropolis is a person's name who proposed this method.)

Veach proposed the initial guess is done by a bidirectional path tracer. If we could find a path that can reach to any light source, we perturbate the path and exploit more paths exist or not.

By the way, I used some kind of variational method for geometry processing. A problem is interpreted to some kind of potential energy problem and is applied a variational method. But the energy design is the problem. Once you have a nice energy, then perturbate your solution and get the better solution. For the light transport problem, it seems difficult to find a derivative, but, the basic idea of Metropolis algorithm looks surprisingly similar.

I enjoyed the Veach's paper. This paper uses a kind of basic and orthodox methods. Basic and orthodox are well established and so many times challenged, therefore I like them.

My personal annotations of Veach's paper ends now. Thanks a lot. So, what will be the next?

Comments

Popular posts from this blog

Why A^{T}A is invertible? (2) Linear Algebra

Why A^{T}A has the inverse Let me explain why A^{T}A has the inverse, if the columns of A are independent. First, if a matrix is n by n, and all the columns are independent, then this is a square full rank matrix. Therefore, there is the inverse. So, the problem is when A is a m by n, rectangle matrix.  Strang's explanation is based on null space. Null space and column space are the fundamental of the linear algebra. This explanation is simple and clear. However, when I was a University student, I did not recall the explanation of the null space in my linear algebra class. Maybe I was careless. I regret that... Explanation based on null space This explanation is based on Strang's book. Column space and null space are the main characters. Let's start with this explanation. Assume  x  where x is in the null space of A .  The matrices ( A^{T} A ) and A share the null space as the following: This means, if x is in the null space of A , x is also in the n...

Gauss's quote for positive, negative, and imaginary number

Recently I watched the following great videos about imaginary numbers by Welch Labs. https://youtu.be/T647CGsuOVU?list=PLiaHhY2iBX9g6KIvZ_703G3KJXapKkNaF I like this article about naming of math by Kalid Azad. https://betterexplained.com/articles/learning-tip-idea-name/ Both articles mentioned about Gauss, who suggested to use other names of positive, negative, and imaginary numbers. Gauss wrote these names are wrong and that is one of the reason people didn't get why negative times negative is positive, or, pure positive imaginary times pure positive imaginary is negative real number. I made a few videos about explaining why -1 * -1 = +1, too. Explanation: why -1 * -1 = +1 by pattern https://youtu.be/uD7JRdAzKP8 Explanation: why -1 * -1 = +1 by climbing a mountain https://youtu.be/uD7JRdAzKP8 But actually Gauss's insight is much powerful. The original is in the Gauß, Werke, Bd. 2, S. 178 . Hätte man +1, -1, √-1) nicht positiv, negative, imaginäre (oder gar um...

Why parallelogram area is |ad-bc|?

Here is my question. The area of parallelogram is the difference of these two rectangles (red rectangle - blue rectangle). This is not intuitive for me. If you also think it is not so intuitive, you might interested in my slides. I try to explain this for hight school students. Slides:  A bit intuitive (for me) explanation of area of parallelogram  (to my site, external link) .