2023-02-05 21:52:42 -06:00
|
|
|
---
|
|
|
|
geometry: margin=2cm
|
|
|
|
output: pdf_document
|
|
|
|
---
|
|
|
|
|
2023-02-16 01:14:22 -06:00
|
|
|
# Raytracer part B
|
|
|
|
|
2023-02-16 01:44:31 -06:00
|
|
|
This project implements a raytracer with Blinn-Phong illumination and shadows
|
|
|
|
implemented. The primary formula that is used by this implementation is:
|
2023-02-15 02:36:53 -06:00
|
|
|
|
2023-02-16 01:14:22 -06:00
|
|
|
\begin{equation}
|
|
|
|
I_{\lambda} =
|
|
|
|
k_a O_{d\lambda} +
|
|
|
|
\sum_{i=1}^{n_\textrm{lights}} \left(
|
2023-02-16 01:44:31 -06:00
|
|
|
f_\textrm{att} \cdot
|
|
|
|
S_i \cdot
|
2023-02-16 01:14:22 -06:00
|
|
|
IL_{i\lambda} \left[
|
|
|
|
k_d O_{d\lambda} \max ( 0, \vec{N} \cdot \vec{L_i} ) +
|
|
|
|
k_s O_{s\lambda} \max ( 0, \vec{N} \cdot \vec{H_i} )^n
|
|
|
|
\right]
|
|
|
|
\right)
|
|
|
|
\end{equation}
|
|
|
|
|
|
|
|
Where:
|
|
|
|
|
|
|
|
- $I_{\lambda}$ is the final illumination of the pixel on an object
|
|
|
|
- $k_a$ is the material's ambient reflectivity
|
|
|
|
- $k_d$ is the material's diffuse reflectivity
|
|
|
|
- $k_s$ is the material's specular reflectivity
|
|
|
|
- $n_\textrm{lights}$ is the number of lights
|
2023-02-16 01:44:31 -06:00
|
|
|
- $f_\textrm{att}$ is the light attenuation factor (1.0 if attenuation is not on)
|
|
|
|
- $S_i$ is the shadow coefficient for light $i$
|
2023-02-16 01:14:22 -06:00
|
|
|
- $IL_{i\lambda}$ is the intensity of light $i$
|
|
|
|
- $O_{d\lambda}$ is the object's diffuse color
|
|
|
|
- $O_{s\lambda}$ is the object's specular color
|
|
|
|
- $\vec{N}$ is the normal vector to the object's surface
|
|
|
|
- $\vec{L_i}$ is the direction from the intersection point to the light $i$
|
|
|
|
- $\vec{H_i}$ is halfway between the direction to the light $i$ and the
|
|
|
|
direction to the viewer
|
|
|
|
- $n$ is the exponent for the specular component
|
2023-02-15 02:36:53 -06:00
|
|
|
|
2023-02-16 01:44:31 -06:00
|
|
|
In this report we will look through how these various factors influence the
|
|
|
|
rendering of the scene. All the images along with their source `.txt` files,
|
|
|
|
rendered `.ppm` files, and converted `.png` files can be found in the `examples`
|
|
|
|
directory of this handin.
|
|
|
|
|
2023-02-05 21:52:42 -06:00
|
|
|
## Varying $k_a$
|
|
|
|
|
2023-02-16 01:14:22 -06:00
|
|
|
$k_a$ is the strength of ambient light. It's used as a coefficient for the
|
|
|
|
object's diffuse color, which keeps a constant value independent of the
|
|
|
|
positions of the object, light, and the viewer. In the image below, I varied
|
|
|
|
$k_a$ between 0.2 and 1. Note how the overall color of the ball increases or
|
|
|
|
decreases in brightness when all other factors remain constant.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/22e4b/22e4b83aa54c21e0dd9f6a2b7890e4abd1b27c81" alt="Varying $k_a$"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|
2023-02-05 21:52:42 -06:00
|
|
|
|
|
|
|
## Varying $k_d$
|
|
|
|
|
2023-02-16 01:14:22 -06:00
|
|
|
TODO
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f90bb/f90bb517b0ff97c5c66735a7557e0a62f003b79b" alt="Varying $k_d$"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|
2023-02-05 21:52:42 -06:00
|
|
|
|
|
|
|
## Varying $k_s$
|
|
|
|
|
2023-02-16 01:14:22 -06:00
|
|
|
TODO
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b828d/b828d25dfff799abc5f9a64371a2ab1f27181e76" alt="Varying $k_s$"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|
2023-02-05 21:52:42 -06:00
|
|
|
|
|
|
|
## Varying $n$
|
|
|
|
|
2023-02-16 01:14:22 -06:00
|
|
|
$n$ is the exponent saying how big the radius of the specular highlight should
|
|
|
|
be. In the equation, increasing the exponent usually leads to smaller shines. In
|
|
|
|
the image below, I varied $n$ between 2 and 100. Note how the size of the shine
|
|
|
|
is more focused but covers a smaller area as $n$ increases.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7cd80/7cd8041b4f356e5329e44a7c09b60ae87b58e956" alt="Varying $n$"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|
2023-02-16 01:14:22 -06:00
|
|
|
|
|
|
|
## Multiple lights
|
|
|
|
|
|
|
|
Multiple lights are handled by multiplying each light against an intensity
|
|
|
|
level, and then added together. Unfortunately, this means that the intensity of
|
|
|
|
each light can't be too bright. We rely on the image to not use lights that are
|
|
|
|
too bright. Because this may result in color values above 1.0, the final value
|
|
|
|
is clamped against 1.0. Below is an example of a scene with two lights; one to
|
|
|
|
the left and one to the right:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/73751/7375113e4cefe32376613f97c56c58f012115d86" alt="Multiple lights"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|
2023-02-16 01:14:22 -06:00
|
|
|
|
|
|
|
## Shadows
|
|
|
|
|
|
|
|
Shadows are implemented by pointing a second ray between the intersection point
|
|
|
|
of the original view ray and each light. If the light has something obstructing
|
|
|
|
it in the middle, the light's effect is not used.
|
|
|
|
|
|
|
|
The soft shadow effect is realized by jittering rays across an area. In my
|
|
|
|
implementation, a jitter radius of about 1.0 is used, and 75 rays are shot into
|
|
|
|
uniformly sampled points within that radius. This also has the side effect that
|
|
|
|
rays that are closer to the original ray are sampled more frequently. Each of
|
|
|
|
these rays produces either 0 or 1 depending on if it was obstructed by the
|
|
|
|
object. Taking the proportion of rays that hit as a coefficient for the shadow,
|
|
|
|
we can get some soft shadow effects like this:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7110d/7110df309bfcb70b838d0330fd766fb966816f81" alt="Soft shadows"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|
|
|
|
|
|
|
|
## Light attenuation
|
|
|
|
|
|
|
|
Light attenuation is when more of the light is applied for objects that are
|
|
|
|
closer to a particular light source. The function that's applied is an inverse
|
|
|
|
quadratic formula with respect to the distance the object is from the light:
|
|
|
|
|
|
|
|
\begin{equation}
|
|
|
|
f_\textrm{att}(d) = \frac{1}{c_1 + c_2 d + c_3 d^2}
|
|
|
|
\end{equation}
|
|
|
|
|
|
|
|
Where:
|
|
|
|
|
|
|
|
- $f_\textrm{att}$ is the attenuation factor
|
|
|
|
- $d$ is the distance the object is from the light
|
|
|
|
- $c_1$, $c_2$, and $c_3$ are user-supplied coefficients
|
|
|
|
|
|
|
|
As you can see below, the effect of the light drops off with the distance from
|
|
|
|
the light (light coming from the left):
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d734f/d734f6390cf6c00acda410218511aa9aa08a5716" alt="Light attenuation"{width=360px}
|
|
|
|
\
|
2023-02-16 01:14:22 -06:00
|
|
|
|
|
|
|
## Depth Cueing
|
|
|
|
|
|
|
|
Depth cueing is when the objects further from the viewer have a lower opacity to
|
|
|
|
"fade" into the background in some sense. A good example of this can be seen in
|
|
|
|
the image below; note how the objects are less and less bright the further they
|
|
|
|
are away from the eye.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0711f/0711f036c39d59dce380b2982e55135019788758" alt="Depth cueing"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|
2023-02-16 01:14:22 -06:00
|
|
|
|
|
|
|
## Shortcomings of the model
|
|
|
|
|
|
|
|
The model cannot be used to represent TODO
|
2023-02-05 21:52:42 -06:00
|
|
|
|
|
|
|
# Arbitrary Objects
|
|
|
|
|
2023-02-16 01:14:22 -06:00
|
|
|
data:image/s3,"s3://crabby-images/6b453/6b453f70e76ea8723d87c6f374b7a27b4897fc87" alt="Objects in the scene"{width=360px}
|
2023-02-16 01:44:31 -06:00
|
|
|
\
|