| author | Radek Brich <radek.brich@devl.cz> | 
| Fri, 30 Nov 2007 00:44:51 +0100 | |
| branch | pyrit | 
| changeset 21 | 79b516a3803d | 
| parent 20 | f22952603f29 | 
| child 22 | 76b7bd51d64a | 
| permissions | -rw-r--r-- | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 1 | /* | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 2 | * C++ RayTracer | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 3 | * file: raytracer.cc | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 4 | * | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 5 | * Radek Brich, 2006 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 6 | */ | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 7 | |
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 8 | #ifdef PTHREADS | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 9 | #include <pthread.h> | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 10 | #endif | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 11 | |
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 12 | #include <stdio.h> | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 13 | #include <malloc.h> | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 14 | #include "raytracer.h" | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 15 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 16 | // Hammersley spherical point distribution | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 17 | // http://www.cse.cuhk.edu.hk/~ttwong/papers/udpoint/udpoints.html | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 18 | Vector3 Raytracer::SphereDistribute(int i, int n, float extent, Vector3 &normal) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 19 | {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 20 | float p, t, st, phi, phirad; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 21 | int kk; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 22 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 23 | t = 0; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 24 | for (p=0.5, kk=i; kk; p*=0.5, kk>>=1) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 25 | if (kk & 1) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 26 | t += p; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 27 | t = 1.0 + (t - 1.0)*extent; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 28 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 29 | phi = (i + 0.5) / n; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 30 | phirad = phi * 2.0 * M_PI; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 31 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 32 | st = sqrt(1.0 - t*t); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 33 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 34 | float x, y, z, xx, yy, zz, q; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 35 | x = st * cos(phirad); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 36 | y = st * sin(phirad); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 37 | z = t; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 38 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 39 | // rotate against Y axis | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 40 | q = acos(normal.z); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 41 | zz = z*cos(q) - x*sin(q); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 42 | xx = z*sin(q) + x*cos(q); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 43 | yy = y; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 44 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 45 | // rotate against Z axis | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 46 | q = atan2f(normal.y, normal.x); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 47 | x = xx*cos(q) - yy*sin(q); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 48 | y = xx*sin(q) + yy*cos(q); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 49 | z = zz; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 50 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 51 | return Vector3(x, y, z); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 52 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 53 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 54 | // ---- tyto dve funkce budou v budouci verzi metody objektu PhongShader | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 55 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 56 | // calculate shader function | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 57 | // P is point of intersection, N normal in this point | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 58 | Colour PhongShader_ambient(Material &mat, Vector3 &P) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 59 | {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 60 | Colour col = mat.texture.colour; //mat.texture.evaluate(P); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 61 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 62 | // ambient | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 63 | return mat.ambient * col; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 64 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 65 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 66 | /* | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 67 | P is point of intersection, | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 68 | N normal in this point, | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 69 | R direction of reflected ray, | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 70 | V direction to the viewer | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 71 | */ | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 72 | Colour PhongShader_calculate(Material &mat, Vector3 &P, Vector3 &N, Vector3 &R, Vector3 &V, | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 73 | Light &light) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 74 | {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 75 | Colour I = Colour(); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 76 | Vector3 L = light.pos - P; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 77 | L.normalize(); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 78 | float L_dot_N = dot(L, N); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 79 | float R_dot_V = dot(R, V); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 80 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 81 | Colour col = mat.texture.colour; //mat.texture.evaluate(P); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 82 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 83 | // diffuse | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 84 | I = mat.diffuse * col * light.colour * L_dot_N; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 85 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 86 | // specular | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 87 | if (R_dot_V > 0) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 88 | I += mat.specular * light.colour * powf(R_dot_V, mat.shininess); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 89 | return I; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 90 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 91 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 92 | Colour Raytracer::raytrace(Ray &ray, int depth, Shape *origin_shape) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 93 | {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 94 | float nearest_distance = FLT_MAX; //Infinity | 
| 11 
4d192e13ee84
move nearest_intersection() to Container, add dummy KdTree.load(), plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
10diff
changeset | 95 | Shape *nearest_shape = top->nearest_intersection(origin_shape, ray, nearest_distance); | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 96 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 97 | 	if (nearest_shape == NULL) {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 98 | return bg_colour; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 99 | 	} else {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 100 | Colour acc = Colour(); | 
| 15 
a0a3e334744f
C++ demos: prepare infrastructure, add spheres_shadow.cc
 Radek Brich <radek.brich@devl.cz> parents: 
14diff
changeset | 101 | Vector3 P = ray.o + ray.dir * nearest_distance; // point of intersection | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 102 | Vector3 normal = nearest_shape->normal(P); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 103 | acc = PhongShader_ambient(*nearest_shape->material, P); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 104 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 105 | vector<Light*>::iterator light; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 106 | 		for (light = lights.begin(); light != lights.end(); light++) {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 107 | Vector3 jo, L = (*light)->pos - P; // direction vector to light | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 108 | L.normalize(); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 109 | float L_dot_N = dot(L, normal); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 110 | 			if (L_dot_N > 0) {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 111 | // test if this light is occluded (sharp shadows) | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 112 | 				if ((*light)->cast_shadows) {
 | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 113 | Ray shadow_ray = Ray(P, L); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 114 | float dist = FLT_MAX; | 
| 11 
4d192e13ee84
move nearest_intersection() to Container, add dummy KdTree.load(), plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
10diff
changeset | 115 | if (top->nearest_intersection(nearest_shape, shadow_ray, dist)) | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 116 | continue; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 117 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 118 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 119 | // shading function | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 120 | Vector3 R = L - 2.0 * L_dot_N * normal; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 121 | acc += PhongShader_calculate(*nearest_shape->material, | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 122 | P, normal, R, ray.dir, **light); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 123 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 124 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 125 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 126 | // reflection | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 127 | Vector3 newdir = ray.dir - 2.0 * dot(ray.dir, normal) * normal; | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 128 | 		if (depth < max_depth && nearest_shape->material->reflection > 0.01) {
 | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 129 | Ray newray = Ray(P, newdir); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 130 | Colour refl_col = raytrace(newray, depth + 1, nearest_shape); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 131 | acc += nearest_shape->material->reflection * refl_col; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 132 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 133 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 134 | // refraction | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 135 | /* ... */ | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 136 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 137 | // ambient occlusion | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 138 | if (ao_samples) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 139 | 		{
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 140 | float miss = 0; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 141 | 			for (int i = 0; i < ao_samples; i++) {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 142 | Vector3 dir = SphereDistribute(i, ao_samples, ao_angle, normal); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 143 | Ray ao_ray = Ray(P, dir); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 144 | float dist = ao_distance; | 
| 11 
4d192e13ee84
move nearest_intersection() to Container, add dummy KdTree.load(), plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
10diff
changeset | 145 | Shape *shape_in_way = top->nearest_intersection(nearest_shape, ao_ray, dist); | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 146 | if (shape_in_way == NULL) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 147 | miss += 1.0; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 148 | else | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 149 | miss += dist / ao_distance; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 150 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 151 | float ao_intensity = miss / ao_samples; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 152 | acc = acc * ao_intensity; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 153 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 154 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 155 | return acc; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 156 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 157 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 158 | |
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 159 | static void *renderrow(void *data) | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 160 | {
 | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 161 | RenderrowData *d = (RenderrowData*) data; | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 162 | int subsample = d->rt->getSubsample(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 163 | float subsample2 = 1.0/(subsample*subsample); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 164 | int ww = d->w*3; | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 165 | Vector3 dir = d->dfix; | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 166 | 	for (int x = 0; x < d->w; x += subsample) {
 | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 167 | // generate a ray from eye passing through this pixel | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 168 | #if OVERSAMPLING | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 169 | // 5x oversampling | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 170 | Colour c = Colour(); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 171 | |
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 172 | for (int i = 0; i < 5; i++) | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 173 | 		{
 | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 174 | 			float osax[] = {0.0, -0.4, +0.4, +0.4, -0.4};
 | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 175 | 			float osay[] = {0.0, -0.4, -0.4, +0.4, +0.4};
 | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 176 | Vector3 tmpdir = dir + osax[i]*d->dx + osay[i]*d->dy; | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 177 | tmpdir.normalize(); | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 178 | Ray ray(d->eye, tmpdir); | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 179 | c += d->rt->raytrace(ray, 0, NULL); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 180 | } | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 181 | c = c * (1./5); | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 182 | #else | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 183 | // no oversampling | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 184 | dir.normalize(); | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 185 | Ray ray(d->eye, dir); | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 186 | Colour c = d->rt->raytrace(ray, 0, NULL); | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 187 | if (subsample > 1) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 188 | 		{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 189 | Colour ic; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 190 | // top-left is 'c' | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 191 | // top-right | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 192 | Vector3 tmpdir = dir + (subsample-1)*d->dx; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 193 | tmpdir.normalize(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 194 | Ray ray(d->eye, tmpdir); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 195 | Colour c2 = d->rt->raytrace(ray, 0, NULL); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 196 | // bottom right | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 197 | tmpdir += (subsample-1)*d->dy; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 198 | tmpdir.normalize(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 199 | ray.dir = tmpdir; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 200 | Colour c4 = d->rt->raytrace(ray, 0, NULL); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 201 | // bottom left | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 202 | tmpdir = dir + (subsample-1)*d->dy; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 203 | tmpdir.normalize(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 204 | ray.dir = tmpdir; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 205 | Colour c3 = d->rt->raytrace(ray, 0, NULL); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 206 | // are the colors similar? | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 207 | float m = (c-c2).mag2(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 208 | m = max(m, (c2-c3).mag2()); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 209 | m = max(m, (c3-c4).mag2()); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 210 | m = max(m, (c4-c).mag2()); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 211 | if (m < 0.001) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 212 | 			{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 213 | // interpolate | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 214 | float *i = d->iter; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 215 | for (int x = 0; x < subsample; x++) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 216 | 				{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 217 | for (int y = 0; y < subsample; y++) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 218 | 					{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 219 | ic = c*(subsample-x)*(subsample-y)*subsample2 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 220 | + c2*(x)*(subsample-y)*subsample2 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 221 | + c3*(subsample-x)*(y)*subsample2 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 222 | + c4*(x)*(y)*subsample2; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 223 | *(i + ww*y) = ic.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 224 | *(i + ww*y + 1) = ic.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 225 | *(i + ww*y + 2) = ic.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 226 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 227 | i += 3; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 228 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 229 | d->iter = i; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 230 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 231 | else | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 232 | 			{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 233 | // render | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 234 | Vector3 tmpdir = dir; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 235 | // first column | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 236 | *(d->iter) = c.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 237 | *(d->iter + 1) = c.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 238 | *(d->iter + 2) = c.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 239 | for (int y = 1; y < subsample-1; y++) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 240 | 				{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 241 | Vector3 tmp2dir = tmpdir + y*d->dy; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 242 | tmp2dir.normalize(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 243 | ray.dir = tmp2dir; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 244 | ic = d->rt->raytrace(ray, 0, NULL); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 245 | *(d->iter + ww*y) = ic.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 246 | *(d->iter + ww*y + 1) = ic.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 247 | *(d->iter + ww*y + 2) = ic.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 248 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 249 | *(d->iter + ww*(subsample-1)) = c3.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 250 | *(d->iter + ww*(subsample-1) + 1) = c3.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 251 | *(d->iter + ww*(subsample-1) + 2) = c3.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 252 | d->iter += 3; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 253 | tmpdir += d->dx; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 254 | // middle | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 255 | for (int x = 1; x < subsample-1; x++) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 256 | 				{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 257 | for (int y = 0; y < subsample; y++) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 258 | 					{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 259 | Vector3 tmp2dir = tmpdir + y*d->dy; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 260 | tmp2dir.normalize(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 261 | ray.dir = tmp2dir; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 262 | ic = d->rt->raytrace(ray, 0, NULL); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 263 | *(d->iter + ww*y) = ic.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 264 | *(d->iter + ww*y + 1) = ic.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 265 | *(d->iter + ww*y + 2) = ic.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 266 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 267 | d->iter += 3; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 268 | tmpdir += d->dx; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 269 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 270 | // last column | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 271 | *(d->iter) = c2.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 272 | *(d->iter + 1) = c2.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 273 | *(d->iter + 2) = c2.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 274 | for (int y = 1; y < subsample-1; y++) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 275 | 				{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 276 | Vector3 tmp2dir = tmpdir + y*d->dy; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 277 | tmp2dir.normalize(); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 278 | ray.dir = tmp2dir; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 279 | ic = d->rt->raytrace(ray, 0, NULL); | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 280 | *(d->iter + ww*y) = ic.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 281 | *(d->iter + ww*y + 1) = ic.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 282 | *(d->iter + ww*y + 2) = ic.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 283 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 284 | *(d->iter + ww*(subsample-1)) = c4.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 285 | *(d->iter + ww*(subsample-1) + 1) = c4.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 286 | *(d->iter + ww*(subsample-1) + 2) = c4.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 287 | d->iter += 3; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 288 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 289 | } | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 290 | #endif | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 291 | if (subsample <= 1) | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 292 | 		{
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 293 | *d->iter++ = c.r; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 294 | *d->iter++ = c.g; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 295 | *d->iter++ = c.b; | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 296 | } | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 297 | dir += d->dx*subsample; | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 298 | } | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 299 | #ifdef PTHREADS | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 300 | pthread_exit((void *)d); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 301 | #endif | 
| 6 
d8d596d26f25
pthreads and other fixes for Windows
 Radek Brich <radek.brich@devl.cz> parents: 
5diff
changeset | 302 | return (void *)d; | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 303 | } | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 304 | |
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 305 | void Raytracer::render(int w, int h, float *buffer) | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 306 | {
 | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 307 | if (!camera || !top || !buffer) | 
| 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 308 | return; | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 309 | |
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 310 | RenderrowData *d; | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 311 | |
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 312 | float S = 0.5/w; | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 313 | Vector3 dfix = camera->u*(-w/2.0*S/camera->f) | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 314 | + camera->v*(h/2.0*S/camera->f) + camera->p; | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 315 | Vector3 dx = camera->u * (S/camera->f); | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 316 | Vector3 dy = camera->v * (-S/camera->f); | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 317 | |
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 318 | #ifdef PTHREADS | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 319 | 	infomsg("* pthreads enabled, using %d threads\n", num_threads);
 | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 320 | pthread_t threads[num_threads]; | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 321 | for (int t = 0; t < num_threads; t++) | 
| 6 
d8d596d26f25
pthreads and other fixes for Windows
 Radek Brich <radek.brich@devl.cz> parents: 
5diff
changeset | 322 | threads[t] = pthread_self(); | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 323 | int t = 0; | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 324 | #endif | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 325 | |
| 15 
a0a3e334744f
C++ demos: prepare infrastructure, add spheres_shadow.cc
 Radek Brich <radek.brich@devl.cz> parents: 
14diff
changeset | 326 | /* for each pixel... */ | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 327 | 	infomsg("* rendering row   0 (  0%% done)");
 | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 328 | for (int y = 0; y < h; y += subsample) | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 329 | 	{
 | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 330 | d = (RenderrowData*) malloc(sizeof(RenderrowData)); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 331 | d->rt = this; | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 332 | d->w = w; | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 333 | d->eye = camera->eye; | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
16diff
changeset | 334 | d->dfix = dfix; | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 335 | d->dx = dx; | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 336 | d->dy = dy; | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 337 | d->iter = buffer + y*3*w; | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 338 | #ifdef PTHREADS | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 339 | /* create new thread and increase 't' */ | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 340 | int rc = pthread_create(&threads[t++], NULL, renderrow, (void *)d); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 341 | 		if (rc) {
 | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 342 | 			infomsg("\nERROR: return code from pthread_create() is %d\n", rc);
 | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 343 | exit(1); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 344 | } | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 345 | /* when 't' owerflows, reset it */ | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 346 | if (t >= num_threads) | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 347 | t = 0; | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 348 | /* wait for next thread in fifo queue, so the descriptor can be reused; | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 349 | this also limits number of running threads */ | 
| 6 
d8d596d26f25
pthreads and other fixes for Windows
 Radek Brich <radek.brich@devl.cz> parents: 
5diff
changeset | 350 | if (!pthread_equal(threads[t], pthread_self())) | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 351 | if (pthread_join(threads[t], (void**)&d) == 0) | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 352 | free(d); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 353 | #else | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 354 | renderrow((void *)d); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 355 | free(d); | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 356 | #endif | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 357 | dfix += dy*subsample; | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 358 | 		infomsg("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b%4d (%2d%% done)", y, y*100/(h-1));
 | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 359 | } | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 360 | 	infomsg("\n");
 | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 361 | |
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 362 | #ifdef PTHREADS | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 363 | 	infomsg("* waiting for threads to finish\n");
 | 
| 4 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 364 | for (t = 0; t < num_threads; t++) | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 365 | if (pthread_join(threads[t], (void**)&d) == 0) | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 366 | free(d); | 
| 
c73bc405ee7a
multi-threaded rendering via pthreads
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 367 | #endif | 
| 0 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 368 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 369 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 370 | void Raytracer::addlight(Light *light) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 371 | {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 372 | lights.push_back(light); | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 373 | } | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 374 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 375 | void Raytracer::ambientocclusion(int samples, float distance, float angle) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 376 | {
 | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 377 | ao_samples = samples; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 378 | ao_distance = distance; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 379 | ao_angle = angle; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 380 | if (ao_distance == 0) | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 381 | /* 0 ==> Inf */ | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 382 | ao_distance = FLT_MAX; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 383 | } |