Skip to content

arindas/quartz

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

quartz

A shared memory parallelism based ray tracing engine.

antialiased sphere 1080p

Building:

git clone [email protected]:arindas/quartz.git
cd quartz/
mkdir build && cd build
cmake .. && make

This produces a binary quartz at quartz/build/quartz.

Usage:

Right now, quartz writes .ppm images to the standard output. Hence, users are requested to redirect it's output to a file:

./quartz > output_image.ppm

Most image viewers can view .ppm files natively. However, for conveniently sharing the images, ppm images can be converted to other formats using ImageMagick's convert tool on Linux. For instance, to convert to png:

convert output_image.ppm output_image.png

Later, quartz will have native support for multiple formats.

Configuration:

quartz at it's core is a header only library. All scene configuration is specified in quartz/main.cc, it being the only c++ source file in this repository.

Image size is configured as:

...
quartz::image_size size = quartz::get_image_size(16.0 / 9.0, // aspect ratio
                                                 225);       // image height
...

Objects can be added to the scene as follows:

...
quartz::scene world;
world.add(std::make_shared<quartz::sphere>(
    quartz::point3(0, 0, -1), 0.5));
world.add(std::make_shared<quartz::sphere>(
    quartz::point3(0, -100.5, -1), 100));
...

Right now, only spheres are supported. Support for multiple 3D objects will be added later.

quartz supports antialiasing. The number of samples per pixel is specified at the time of invoking quartz::renderer::render():

...
quartz::renderer renderer_(size, world);

int samples_per_pixel = 100;
renderer_.render(tracer, cam, samples_per_pixel);
...

Camera properties are configured as follows:

...
quartz::point3 lookfrom(3, 3, 2);
quartz::point3 lookat(0, 0, -1);
quartz::vec3<double> vup(0, 1, 0);
auto dist_to_focus = (lookfrom - lookat).length();
auto aperture = 2.0;

quartz::camera cam(lookfrom, lookat, vup, 20, aspect_ratio, aperture, dist_to_focus);
...

quartz renders images to an in-memory buffer (quartz::image_sink) first. The contents of this buffer are later serialized by different implementations of quartz::image_writer. The only quartz::image_writer implementation right now is quartz::ppm_image_writer.

TODO

  • Add support for different materials
  • Parallelize the render loop
  • Add support for camera
  • Add support for different image formats.
  • Add support for multiple 3D hittables.