clray
changeset 25:58642a8316b7
continuing with the kdtree
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Sat, 14 Aug 2010 07:00:04 +0100 (2010-08-14) |
parents | 13091c00d7ca |
children | c740ae431d51 |
files | src/scene.cc src/scene.h |
diffstat | 2 files changed, 70 insertions(+), 6 deletions(-) [+] |
line diff
1.1 --- a/src/scene.cc Sat Aug 14 03:02:52 2010 +0100 1.2 +++ b/src/scene.cc Sat Aug 14 07:00:04 2010 +0100 1.3 @@ -1,4 +1,5 @@ 1.4 #include <math.h> 1.5 +#include <float.h> 1.6 #include "scene.h" 1.7 1.8 #define FEQ(a, b) (fabs((a) - (b)) < 1e-8) 1.9 @@ -20,6 +21,16 @@ 1.10 return true; 1.11 } 1.12 1.13 +float AABBox::calc_surface_area() const 1.14 +{ 1.15 + float area1 = (max[0] - min[0]) * (max[1] - min[1]); 1.16 + float area2 = (max[3] - min[3]) * (max[1] - min[1]); 1.17 + float area3 = (max[0] - min[0]) * (max[3] - min[3]); 1.18 + 1.19 + return 2.0f * (area1 + area2 + area3); 1.20 +} 1.21 + 1.22 + 1.23 Scene::Scene() 1.24 { 1.25 facebuf = 0; 1.26 @@ -113,21 +124,66 @@ 1.27 return facebuf; 1.28 } 1.29 1.30 -static void build_kdtree(KDNode **kd, std::list<const Face*> *faces); 1.31 +static int build_kdtree(KDNode *kd); 1.32 +static void free_kdtree(KDNode *node); 1.33 1.34 void Scene::build_kdtree() 1.35 { 1.36 const Face *faces = get_face_buffer(); 1.37 int num_faces = get_num_faces(); 1.38 1.39 - std::list<const Face*> facelist; 1.40 + printf("Constructing kd-tree out of %d faces ...\n", num_faces); 1.41 + 1.42 + free_kdtree(kdtree); 1.43 + kdtree = new KDNode; 1.44 + kdtree->left = kdtree->right = 0; 1.45 + 1.46 + /* Start the construction of the kdtree by adding all faces of the scene 1.47 + * to the new root node. At the same time calculate the root's AABB. 1.48 + */ 1.49 + kdtree->aabb.min[0] = kdtree->aabb.min[1] = kdtree->aabb.min[2] = FLT_MAX; 1.50 + kdtree->aabb.max[0] = kdtree->aabb.max[1] = kdtree->aabb.max[2] = -FLT_MAX; 1.51 + 1.52 for(int i=0; i<num_faces; i++) { 1.53 - facelist.push_back(faces + i); 1.54 + const Face *face = faces + i; 1.55 + 1.56 + // for each vertex of the face ... 1.57 + for(int j=0; j<3; j++) { 1.58 + const float *pos = face->v[j].pos; 1.59 + 1.60 + // for each element (xyz) of the position vector ... 1.61 + for(int k=0; k<3; k++) { 1.62 + if(pos[k] < kdtree->aabb.min[k]) { 1.63 + kdtree->aabb.min[k] = pos[k]; 1.64 + } 1.65 + if(pos[k] > kdtree->aabb.max[k]) { 1.66 + kdtree->aabb.max[k] = pos[k]; 1.67 + } 1.68 + } 1.69 + } 1.70 + 1.71 + kdtree->faces.push_back(face); // add the face 1.72 } 1.73 1.74 - ::build_kdtree(&kdtree, &facelist); 1.75 + // now proceed splitting the root recursively 1.76 + ::build_kdtree(kdtree); 1.77 } 1.78 1.79 -static void build_kdtree(KDNode **kd, std::list<const Face*> *faces) 1.80 +static int build_kdtree(KDNode *kd) 1.81 { 1.82 + if(kd->faces.empty()) { 1.83 + return 0; 1.84 + } 1.85 + 1.86 + // XXX cont. 1.87 + return -1; 1.88 } 1.89 + 1.90 +static void free_kdtree(KDNode *node) 1.91 +{ 1.92 + if(node) { 1.93 + free_kdtree(node->left); 1.94 + free_kdtree(node->right); 1.95 + delete node; 1.96 + } 1.97 +}
2.1 --- a/src/scene.h Sat Aug 14 03:02:52 2010 +0100 2.2 +++ b/src/scene.h Sat Aug 14 07:00:04 2010 +0100 2.3 @@ -33,6 +33,13 @@ 2.4 int matid; 2.5 }; 2.6 2.7 +class AABBox { 2.8 +public: 2.9 + float min[4], max[4]; 2.10 + 2.11 + float calc_surface_area() const; 2.12 +}; 2.13 + 2.14 enum { 2.15 KDAXIS_X, 2.16 KDAXIS_Y, 2.17 @@ -48,9 +55,10 @@ 2.18 struct KDNode { 2.19 int axis; 2.20 float pt; 2.21 + AABBox aabb; 2.22 2.23 KDNode *left, *right; 2.24 - std::list<Face*> faces; 2.25 + std::list<const Face*> faces; 2.26 }; 2.27 2.28 struct KDNodeGPU {