| author | Radek Brich <radek.brich@devl.cz> | 
| Wed, 19 Mar 2008 17:18:59 +0100 | |
| branch | pyrit | 
| changeset 45 | 76b254ce92cf | 
| parent 44 | 3763b26244f0 | 
| child 46 | 6493fb65f0b1 | 
| 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 | /* | 
| 44 | 2 | * scene.h: classes for objects in scene | 
| 3 | * | |
| 4 | * This file is part of Pyrit Ray Tracer. | |
| 5 | * | |
| 6 | * Copyright 2006, 2007 Radek Brich | |
| 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 | 7 | * | 
| 44 | 8 | * Permission is hereby granted, free of charge, to any person obtaining a copy | 
| 9 | * of this software and associated documentation files (the "Software"), to deal | |
| 10 | * in the Software without restriction, including without limitation the rights | |
| 11 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | |
| 12 | * copies of the Software, and to permit persons to whom the Software is | |
| 13 | * furnished to do so, subject to the following conditions: | |
| 14 | * | |
| 15 | * The above copyright notice and this permission notice shall be included in | |
| 16 | * all copies or substantial portions of the Software. | |
| 17 | * | |
| 18 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | |
| 19 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | |
| 20 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | |
| 21 | * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | |
| 22 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | |
| 23 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | |
| 24 | * THE SOFTWARE. | |
| 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 | 25 | */ | 
| 
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 | |
| 
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 | #ifndef SCENE_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 | 28 | #define SCENE_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 | 29 | |
| 
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 | #include <vector> | 
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 31 | #include <typeinfo> | 
| 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 | 32 | |
| 
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 | #include "noise.h" | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 34 | #include "vector.h" | 
| 34 
28f6e8b9d5d1
quaternion moved to extra header file
 Radek Brich <radek.brich@devl.cz> parents: 
31diff
changeset | 35 | #include "quaternion.h" | 
| 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 | 36 | |
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 37 | /* | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 38 | triangle intersection alghoritm | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 39 | chooses are: | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 40 | TRI_PLUCKER | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 41 | TRI_BARI | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 42 | TRI_BARI_PRE | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 43 | */ | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 44 | #if !defined(TRI_PLUCKER) && !defined(TRI_BARI) && !defined(TRI_BARI_PRE) | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 45 | # define TRI_BARI_PRE | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 46 | #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 | 47 | |
| 
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 | using namespace std; | 
| 
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 | |
| 12 
f4fcabf05785
kd-tree: traversal algorithm (KdTree::nearest_intersection)
 Radek Brich <radek.brich@devl.cz> parents: 
9diff
changeset | 50 | class Ray | 
| 
f4fcabf05785
kd-tree: traversal algorithm (KdTree::nearest_intersection)
 Radek Brich <radek.brich@devl.cz> parents: 
9diff
changeset | 51 | {
 | 
| 
f4fcabf05785
kd-tree: traversal algorithm (KdTree::nearest_intersection)
 Radek Brich <radek.brich@devl.cz> parents: 
9diff
changeset | 52 | public: | 
| 15 
a0a3e334744f
C++ demos: prepare infrastructure, add spheres_shadow.cc
 Radek Brich <radek.brich@devl.cz> parents: 
14diff
changeset | 53 | Vector3 o, dir; | 
| 
a0a3e334744f
C++ demos: prepare infrastructure, add spheres_shadow.cc
 Radek Brich <radek.brich@devl.cz> parents: 
14diff
changeset | 54 | Ray(const Vector3 &ao, const Vector3 &adir): | 
| 
a0a3e334744f
C++ demos: prepare infrastructure, add spheres_shadow.cc
 Radek Brich <radek.brich@devl.cz> parents: 
14diff
changeset | 55 | 		o(ao), dir(adir) {};
 | 
| 12 
f4fcabf05785
kd-tree: traversal algorithm (KdTree::nearest_intersection)
 Radek Brich <radek.brich@devl.cz> parents: 
9diff
changeset | 56 | }; | 
| 
f4fcabf05785
kd-tree: traversal algorithm (KdTree::nearest_intersection)
 Radek Brich <radek.brich@devl.cz> parents: 
9diff
changeset | 57 | |
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 58 | class Camera | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 59 | {
 | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 60 | public: | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 61 | Vector3 eye, p, u, v; | 
| 22 | 62 | Float f; | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 63 | |
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 64 | 	Camera(): eye(0,0,10), p(0,0,-1), u(-1,0,0), v(0,1,0), f(3.14/4.0) {};
 | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 65 | Camera(const Vector3 &C, const Vector3 &ap, const Vector3 &au, const Vector3 &av): | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 66 | 		eye(C), p(ap), u(au), v(av), f(3.14/4.0) {};
 | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 67 | 	void setEye(const Vector3 &aeye) { eye = aeye; };
 | 
| 22 | 68 | 	void setFocalLength(const Float af) { f = af; };
 | 
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 69 | void rotate(const Quaternion &q); | 
| 22 | 70 | void move(const Float fw, const Float left, const Float up); | 
| 19 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 71 | }; | 
| 
4e0955fca797
added Camera, currently w/o Python binding
 Radek Brich <radek.brich@devl.cz> parents: 
15diff
changeset | 72 | |
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 73 | /* axis-aligned bounding box */ | 
| 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 74 | class BBox | 
| 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 75 | {
 | 
| 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 76 | public: | 
| 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 77 | Vector3 L; | 
| 14 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 78 | Vector3 H; | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 79 | 	BBox(): L(), H() {};
 | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 80 | 	BBox(const Vector3 aL, const Vector3 aH): L(aL), H(aH) {};
 | 
| 22 | 81 | 	Float w() { return H.x-L.x; };
 | 
| 82 | 	Float h() { return H.y-L.y; };
 | |
| 83 | 	Float d() { return H.z-L.z; };
 | |
| 84 | bool intersect(const Ray &ray, Float &a, Float &b); | |
| 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 | 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 | |
| 
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 | class 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 | 88 | {
 | 
| 
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 | public: | 
| 
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 | Vector3 pos; | 
| 
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 | Colour colour; | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 92 | bool 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 | 93 | |
| 40 
929aad02c5f2
Makefile: added help and distclean target, plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
38diff
changeset | 94 | Light(): | 
| 
929aad02c5f2
Makefile: added help and distclean target, plus small fixes
 Radek Brich <radek.brich@devl.cz> parents: 
38diff
changeset | 95 | 		pos(Vector3(0,0,0)), colour(Colour(1,1,1)), cast_shadows(true) {};
 | 
| 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 | Light(const Vector3 &position, const Colour &acolour): | 
| 21 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 97 | 		pos(position), colour(acolour), cast_shadows(true) {};
 | 
| 
79b516a3803d
naive color driven sub-sampling
 Radek Brich <radek.brich@devl.cz> parents: 
20diff
changeset | 98 | 	void castShadows(bool cast) { cast_shadows = cast; };
 | 
| 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 | 99 | }; | 
| 
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 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 101 | class Texture | 
| 
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 | {
 | 
| 
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 | public: | 
| 42 | 104 | virtual Colour evaluate(Vector3 point) = 0; | 
| 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 | 105 | }; | 
| 
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 | |
| 
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 | class 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 | 108 | {
 | 
| 
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 | public: | 
| 42 | 110 | Colour colour; | 
| 22 | 111 | Float ambient, diffuse, specular, shininess; // Phong constants | 
| 31 | 112 | Float reflectivity; // how much reflective is the surface | 
| 113 | Float transmissivity, refract_index; // part of light which can be refracted; index of refraction | |
| 42 | 114 | Texture *texture; | 
| 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 | 115 | |
| 42 | 116 | Material(const Colour &acolour): colour(acolour), texture(NULL) | 
| 117 | 	{
 | |
| 31 | 118 | ambient = 0.2; | 
| 119 | diffuse = 0.8; | |
| 120 | specular = 0.2; | |
| 20 
f22952603f29
new C++ demo: realtime.cc (real-time scene viewer using SDL)
 Radek Brich <radek.brich@devl.cz> parents: 
19diff
changeset | 121 | shininess = 0.5; | 
| 31 | 122 | reflectivity = 0.2; | 
| 123 | transmissivity = 0.0; | |
| 124 | refract_index = 1.3; | |
| 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 | 125 | } | 
| 31 | 126 | |
| 127 | void setPhong(const Float amb, const Float dif, const Float spec, const Float shin) | |
| 128 | 		{ ambient = amb; diffuse = dif; specular = spec; shininess = shin; };
 | |
| 129 | 	void setReflectivity(const Float refl) { reflectivity = refl; };
 | |
| 130 | void setTransmissivity(const Float trans, const Float rindex) | |
| 131 | 		{ transmissivity = trans; refract_index = rindex; };
 | |
| 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 | 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 | class 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 | 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 | public: | 
| 
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 | Material *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 | 138 | 	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 | 139 | 	virtual ~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 | 140 | |
| 
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 | // first intersection point | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 142 | virtual bool intersect(const Ray &ray, Float &dist) const = 0; | 
| 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 | 143 | |
| 
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 | // all intersections (only for CSG) | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 145 | virtual bool intersect_all(const Ray &ray, Float dist, vector<Float> &allts) const = 0; | 
| 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 | |
| 36 
b490093b0ac3
new virtual Shape::intersect_bbox
 Radek Brich <radek.brich@devl.cz> parents: 
34diff
changeset | 147 | // intersection with AABB | 
| 
b490093b0ac3
new virtual Shape::intersect_bbox
 Radek Brich <radek.brich@devl.cz> parents: 
34diff
changeset | 148 | virtual bool intersect_bbox(const BBox &bbox) const = 0; | 
| 
b490093b0ac3
new virtual Shape::intersect_bbox
 Radek Brich <radek.brich@devl.cz> parents: 
34diff
changeset | 149 | |
| 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 | 150 | // normal at point P | 
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 151 | virtual const Vector3 normal(const Vector3 &P) const = 0; | 
| 7 
bf17f9f84c91
kd-tree: build algorithm - searching for all posible splits
 Radek Brich <radek.brich@devl.cz> parents: 
0diff
changeset | 152 | |
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 153 | virtual BBox get_bbox() const = 0; | 
| 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 | 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 | |
| 24 
d0d76e8a5203
new C++ demo: realtime_dragon.cc
 Radek Brich <radek.brich@devl.cz> parents: 
22diff
changeset | 156 | class ShapeList: public vector<Shape*> | 
| 
d0d76e8a5203
new C++ demo: realtime_dragon.cc
 Radek Brich <radek.brich@devl.cz> parents: 
22diff
changeset | 157 | {
 | 
| 
d0d76e8a5203
new C++ demo: realtime_dragon.cc
 Radek Brich <radek.brich@devl.cz> parents: 
22diff
changeset | 158 | }; | 
| 
d0d76e8a5203
new C++ demo: realtime_dragon.cc
 Radek Brich <radek.brich@devl.cz> parents: 
22diff
changeset | 159 | |
| 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 | 160 | class Sphere: public 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 | 161 | {
 | 
| 22 | 162 | Float sqr_radius; | 
| 163 | Float inv_radius; | |
| 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 | 164 | public: | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 165 | Vector3 center; | 
| 22 | 166 | Float radius; | 
| 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 | 167 | |
| 22 | 168 | Sphere(const Vector3 &acenter, const Float aradius, Material *amaterial): | 
| 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 | 169 | sqr_radius(aradius*aradius), inv_radius(1.0f/aradius), | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 170 | 		center(acenter), radius(aradius) { material = amaterial; }
 | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 171 | bool intersect(const Ray &ray, Float &dist) const; | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 172 | bool intersect_all(const Ray &ray, Float dist, vector<Float> &allts) const; | 
| 38 
5d043eeb09d9
realtime_dragon demo: now fullsize model + octree
 Radek Brich <radek.brich@devl.cz> parents: 
36diff
changeset | 173 | bool intersect_bbox(const BBox &bbox) const; | 
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 174 | 	const Vector3 normal(const Vector3 &P) const { return (P - center) * inv_radius; };
 | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 175 | BBox get_bbox() const; | 
| 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 | 176 | }; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 177 | |
| 14 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 178 | class Box: public Shape | 
| 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 | 179 | {
 | 
| 14 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 180 | Vector3 L; | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 181 | Vector3 H; | 
| 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 | 182 | public: | 
| 14 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 183 | Box(const Vector3 &aL, const Vector3 &aH, Material *amaterial): L(aL), H(aH) | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 184 | 	{
 | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 185 | for (int i = 0; i < 3; i++) | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 186 | if (L.cell[i] > H.cell[i]) | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 187 | swap(L.cell[i], H.cell[i]); | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 188 | material = amaterial; | 
| 
fc18ac4833f2
replace Plane with axis-aligned Box (because infinite Plane is not usable with kd-tree)
 Radek Brich <radek.brich@devl.cz> parents: 
12diff
changeset | 189 | }; | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 190 | bool intersect(const Ray &ray, Float &dist) const; | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 191 | 	bool intersect_all(const Ray &ray, Float dist, vector<Float> &allts) const { return false; };
 | 
| 38 
5d043eeb09d9
realtime_dragon demo: now fullsize model + octree
 Radek Brich <radek.brich@devl.cz> parents: 
36diff
changeset | 192 | bool intersect_bbox(const BBox &bbox) const; | 
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 193 | const Vector3 normal(const Vector3 &P) const; | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 194 | 	BBox get_bbox() const { return BBox(L, H); };
 | 
| 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 | 195 | }; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 196 | |
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 197 | class Vertex | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 198 | {
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 199 | public: | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 200 | Vector3 P; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 201 | 	Vertex(const Vector3 &aP): P(aP) {};
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 202 | }; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 203 | |
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 204 | class NormalVertex: public Vertex | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 205 | {
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 206 | public: | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 207 | Vector3 N; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 208 | 	NormalVertex(const Vector3 &aP): Vertex(aP) {};
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 209 | 	NormalVertex(const Vector3 &aP, const Vector3 &aN): Vertex(aP), N(aN) {};
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 210 | 	const Vector3 &getNormal() { return N; };
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 211 | 	void setNormal(const Vector3 &aN) { N = aN; };
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 212 | }; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 213 | |
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 214 | |
| 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 | 215 | class Triangle: public 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 | 216 | {
 | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 217 | #ifdef TRI_BARI_PRE | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 218 | Float nu, nv, nd; | 
| 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 | 219 | int k; // dominant axis | 
| 22 | 220 | Float bnu, bnv; | 
| 221 | Float cnu, cnv; | |
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 222 | #endif | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 223 | #ifdef TRI_BARI | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 224 | int k; // dominant axis | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 225 | #endif | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 226 | #ifdef TRI_PLUCKER | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 227 | Float pla[6], plb[6], plc[6]; | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 228 | #endif | 
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 229 | Vector3 N; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 230 | bool smooth; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 231 | const Vector3 smooth_normal(const Vector3 &P) const | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 232 | 	{
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 233 | #ifdef TRI_BARI_PRE | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 234 | const Vector3 &NA = static_cast<NormalVertex*>(A)->N; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 235 | const Vector3 &NB = static_cast<NormalVertex*>(B)->N; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 236 | const Vector3 &NC = static_cast<NormalVertex*>(C)->N; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 237 | 		static const int modulo3[5] = {0,1,2,0,1};
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 238 | register const int ku = modulo3[k+1]; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 239 | register const int kv = modulo3[k+2]; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 240 | const Float pu = P[ku] - A->P[ku]; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 241 | const Float pv = P[kv] - A->P[kv]; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 242 | const Float u = pv * bnu + pu * bnv; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 243 | const Float v = pu * cnv + pv * cnu; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 244 | Vector3 n = NA + u * (NB - NA) + v * (NC - NA); | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 245 | n.normalize(); | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 246 | return n; | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 247 | #else | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 248 | return N; // not implemented for other algorithms | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 249 | #endif | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 250 | }; | 
| 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 | 251 | public: | 
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 252 | Vertex *A, *B, *C; | 
| 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 | 253 | |
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 254 | Triangle(Vertex *aA, Vertex *aB, Vertex *aC, Material *amaterial); | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 255 | bool intersect(const Ray &ray, Float &dist) const; | 
| 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 256 | 	bool intersect_all(const Ray &ray, Float dist, vector<Float> &allts) const {return false;};
 | 
| 36 
b490093b0ac3
new virtual Shape::intersect_bbox
 Radek Brich <radek.brich@devl.cz> parents: 
34diff
changeset | 257 | bool intersect_bbox(const BBox &bbox) const; | 
| 28 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 258 | 	const Vector3 normal(const Vector3 &P) const { return (smooth ? smooth_normal(P) : N); };
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 259 | 	const Vector3 getNormal() const { return N; };
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 260 | 	void setSmooth() { smooth = true; };//(typeid(*A) == typeid(*B) == typeid(*C) == typeid(NormalVertex)); };
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 261 | 	void setFlat() { smooth = false; };
 | 
| 
ffe83ca074f3
smooth triangles (aka Phong shading)
 Radek Brich <radek.brich@devl.cz> parents: 
25diff
changeset | 262 | 	bool getSmooth() const { return smooth; };
 | 
| 25 
b8232edee786
tuned ray-triangle intersection, now there are three algorithms to choose from:
 Radek Brich <radek.brich@devl.cz> parents: 
24diff
changeset | 263 | BBox get_bbox() const; | 
| 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 | 264 | }; | 
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 265 | |
| 
3547b885df7e
initial commit, raytracer source as written year ago and unchanged since 2007-03-25
 Radek Brich <radek.brich@devl.cz> parents: diff
changeset | 266 | #endif |