In the first assignment, you wrote a code to read and manipulate a 3D model from a file in obj format. For this assignment, you will take the first step in rendering a scene with multiple objects and a light sources. More precisely, you will write a program that reads 3D camera specifications and one or more spheres defined in a driver file. To render a colorful scene, you will also read light source specifications and material properties of the objects. You will be asked to demonstrate that your ray casting system is capable of rendering the scenes described in the driver files given to you.
Your illumination model in this assignment will only include ambient and diffuse components. Also, you are explicitly not being asked to perform recursive ray tracing nor are you being asked to handle semi-transparent objects. In other words, no light refracting through spheres. You may anticipate these as additions later in the semester. You will also not be expected to calculate ray-triangle intersections, so there will only be spheres in the driver files with no .obj models.
Your program will take in two command line arguments. The first argument is a driver file containing the camera description and a list of spheres along with their material properties. The second argument is the name of the image your program will write back to the disk in the same folder where your executable is located. A C++ example is:
$./raytracer driver00.txt driver00.ppm
Your program will implement the camera model by throwing a ray from each camera pixel in near clipping plane and determining the closest surface, if any, which lies in the path of the ray. Presuming the ray intersects a surface, then the pixel should be set to a color value determined by the material properties and lighting specifications in the scene. Should a ray fail to intersect any polygon then it is given a default background color; for this assignment set this default to black, (0, 0, 0). Your program will then write out the resulting image as an ASCII PPM color image (P3 format, details provided below) to the filename in the second argument passed to your executable.
The driver file, as you may have figured out, is specific to this class and this semester of CS 410. Modifications have been made to the driver file for this assignment to support camera specifications, scene lighting, and spheres. Here is an example of a driver file for this assignment.
# you may include comments here
eye 25 25 60
look 25 25 10
up 0 1 0
d -10
bounds -1 1 -1 1
res 256 256
ambient 0.2 0.2 0.2
light 5 32 30 1 0.5 1.0 0.5
light 45 32 30 1 1.0 0.5 0.5
sphere 25 25 10 4 0.2 0.2 0.2 0.7 0.7 0.7 0.5 0.5 0.5 1.0 1.0 1.0
eye x y z
Location of the focal point (the eye) with x, y, and z coordinates look x y z
Location of the look at point with x, y, and z coordinates up x y z
Direction of the up vector with x, y, and z coordinates d a
a is the amount to travel to get to the near clipping plane (as the value "near" in cs410lec08n01.ipynb) bounds left right bottom top
The minimum and maximum extent of the bounded image rectangle in the horizontal and vertical directions (i.e. the near clipping plane bounds) res width height
The resolution of the image in pixels. One feature of this specification format is that you can generate intermediate cameras
with low resolution, say 8 by 8 or even 4 by 4, when developing and
debugging code. This speeds development considerably. Do note that
the dimensions of your output image must match the resolution
specification exactly; no off by one errors allowed.
ambient e_r e_g e_b
Ambient light with red (e_r), green (e_g), and blue (e_b) levels.
light x y z w e_r e_g e_b
This specifies the location of the light (x, y, z) and the emittance in red, green, and blue (e_r, e_g, e_b) of the light. The emittance values are between
0 and 1. The fourth value, w, is generally one, but a zero indicates a light source at infinity in the direction specified by x, y, and z. Implementing behavior for a zero w is not necessary for this assignment (but may be for future assignments). There will be one or more of these lights
sphere x y z r Ka_r Ka_g Ka_b Kd_r Kd_g Kd_b Ks_r Ks_g Ks_b Kr_r Kr_g Kr_b
This specifies the location of the sphere (x, y, z) and its radius (r). The K values correspond to different kinds of reflectivity. Ka values are the amount that ambient light is reflected. Kd values are the amount that diffuse light is reflected. Ks values relate to specular lighting. Kr values relate to attenuation. For this assignment, specular and attenuation (Ks and Kr) values will not be used.
In this assignment, you will not encounter models. Later assignments will include the creation of code to display models based on their material properties.
Images should be written as legal ASCII PPM files. Although some variations are permissible, I recommend the following. The first line contains the characters P3 and nothing else. The next line contains the image width, the image height, and the number 255 (the maximum possible pixel value), all integers. Pixel values begin on the next line, and contain 3 values per pixel (a red value, a green value, and a blue value, in that order). Since the total number of pixels in an image is width times height, the number of values in the file (after the two header lines) must be 3 times width times height. To make images “readable” by humans (when they are small), you will want to put a newline at the end of each row. The image generated from this driver file might therefore begin with:
P3
256 256 255
239 239 239 239 239 ...
In this assignment you will construct three scenes: two scenes described in the two driver files given to you and one more scene of your choice by creating your own driver file with any sphere objects of your choice.
In all cases the camera view, lighting, and model transformations and placement should result in a well rendered final image. The image should be written in PPM format as described above. Here are the example ppm outputs for first two driver files. Note that your ppms may not exactly match with these but they should come very close.Submit a tar file via the CANVAS assignment page that includes:
If you are using C++, your executable should be named 'raytracer'. If your are using java, the main executable class should be named 'Raytracer'. Notice the change in case for the first letter between C++ and Java. It is must for this assignment to take exactly two arguments as described above.
There is no “late period”. Key is to start earlier and finish earlier. The program is due when it is due. All work you submit must be your own. You may not copy code from colleagues or the web or anywhere else. Cheating will not be tolerated, and will be handled in accordance with university and department policy.
Drivers and scenes have been uploaded. Additionally the specification for bounds has been specified more clearly - left bound then right bound then bottom bound then top bound.
The d value used to compute the near clipping plane location has had its definition updated. Specifications of driver file lines have been updated.