TODO
author Radek Brich <radek.brich@devl.cz>
Mon, 21 Apr 2008 08:47:36 +0200 (2008-04-21)
branchpyrit
changeset 74 09aedbf5f95f
parent 72 7c3f38dff082
child 75 20dee9819b17
permissions -rw-r--r--
kd-tree traversal - avoid dynamic memory allocation use minimum storage size for KdNode (8B on 32bit cpu) vector.h - add division operator, fix semicolons
Bugs
====
 * (none known)

Future Plans
============
 * changing main ray tracing algoritm to more flexible architecture with a Sampler object:
  - enhance Sampler to support subsampling
 * namespace
 * kd-tree:
   - optimize structures
   - optimize construction: use box-shape intersection instead of bounding boxes of shapes
   - save/load
 * textures (3D procedural, pixmaps)
 * Python binding for all classes
 * stochastic oversampling
 * absorbtion of refracted rays in dense materials (can be computed using shape distance and some 'absorbance' constant)
 * implement efficient AABB-ray intersection using Plucker coordinates
 * generalization: Camera "shader" (ray generator), surface shader and maybe light & background shaders
 * unify capitalization of method names in C++ and Python

New Classes?
============

shapes.h  -- Triangle, Sphere
scene.h   -- Ray, Light, Camera, Scene
material.h -- Material, Texture
reader.h  -- Reader, WavefrontReader

wf = new WavefrontReader()
wf.setContainer(top)
wf.setTransform(monkey_pos_matrix)
wf.read("monkey.obj")
// more transform&reads
destroy wf

Scene scene -- container with shapes, a camera and lights
scene = new Scene()
scene.setCamera(new Camera(eye, u, v, p))
scene.addLight(new PointLight(pos, color))
rt.setScene(scene)
rt.render(w,h)


constructors have zero or one parameter by default -- the object to copy data from
more parameters -- the data (ray origin and direction)