Changeset 262 for trunk/VUT/GtpVisibilityPreprocessor/src
- Timestamp:
- 09/09/05 15:03:48 (19 years ago)
- Location:
- trunk/VUT/GtpVisibilityPreprocessor/src
- Files:
-
- 11 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/VUT/GtpVisibilityPreprocessor/src/Polygon3.cpp
r261 r262 12 12 Polygon3::Polygon3(Face *face, Mesh *parent) 13 13 { 14 VertexIndexContainer:: const_iterator it;14 VertexIndexContainer::reverse_iterator it = face->mVertexIndices.rbegin(); 15 15 16 for ( it = face->mVertexIndices.begin(); it != face->mVertexIndices.end(); ++it)16 for (; it != face->mVertexIndices.rend(); ++it) 17 17 { 18 18 mVertices.push_back(parent->mVertices[*it]); 19 19 mMaterial = parent->mMaterial; 20 20 21 Debug << parent->mVertices[*it] << endl;21 //Debug << parent->mVertices[*it] << endl; 22 22 } 23 23 } … … 31 31 #endif 32 32 return Plane3(mVertices[0], mVertices[1], mVertices[2]); 33 }34 35 void Polygon3::DeletePolygons(PolygonContainer *polys)36 {37 while(!polys->empty())38 {39 DEL_PTR(polys->back());40 polys->pop_back();41 }42 33 } 43 34 -
trunk/VUT/GtpVisibilityPreprocessor/src/Polygon3.h
r256 r262 62 62 63 63 64 /** Deletes all polygons om the queue.65 */66 static void DeletePolygons(PolygonContainer *polys);67 68 64 /// vertices are connected in counterclockwise order. 69 65 VertexContainer mVertices; -
trunk/VUT/GtpVisibilityPreprocessor/src/Preprocessor.cpp
r261 r262 7 7 #include "Environment.h" 8 8 9 Preprocessor::Preprocessor(): 10 mKdTree(NULL), 11 mBspTree(NULL) 12 { 13 } 9 14 10 15 Preprocessor::~Preprocessor() 11 16 { 12 // delete view cells 13 while (!mViewCells.empty()) 14 { 15 DEL_PTR(mViewCells.back()); 16 mViewCells.pop_back(); 17 } 18 19 // delete psp tree 17 CLEAR_CONTAINER(mViewCells); 20 18 DEL_PTR(mBspTree); 19 DEL_PTR(mKdTree); 21 20 } 22 21 … … 25 24 { 26 25 X3dParser *parser = new X3dParser; 27 28 delete parser;29 26 30 27 bool result = parser->ParseFile(filename, mViewCells); … … 32 29 if (result) 33 30 { 34 Exporter *exporter = Exporter::GetExporter( filename);31 Exporter *exporter = Exporter::GetExporter("viewcells.x3d"); 35 32 36 33 if (exporter) 34 { 37 35 exporter->ExportViewCells(&mViewCells); 38 36 delete exporter; 37 } 38 39 Debug << "Generating view cells" << endl; 39 40 GenerateViewCells(); 41 Debug << "Generated view cells" << endl; 40 42 } 43 44 DEL_PTR(parser); 45 46 41 47 return result; 42 48 } … … 91 97 Preprocessor::BuildBspTree() 92 98 { 93 ObjectContainer objects; 94 mSceneGraph->CollectObjects(&objects); 95 99 DEL_PTR(mBspTree); 96 100 mBspTree = new BspTree(); 97 101 … … 116 120 } 117 121 122 ObjectContainer objects; 123 RayContainer rays; 124 118 125 switch (constructionMethod) 119 126 { 120 127 case BspTree::VIEWCELLS: 128 Debug << "Construction method: view cells\n"; 129 121 130 // derive view cells from the scene objects 122 //ViewCell::DeriveViewCells(objects, mViewCells, maxViewCells); 131 if (mViewCells.empty()) 132 { 133 Debug << "View cells empty => generating new ones\n"; Debug.flush(); 134 mSceneGraph->CollectObjects(&objects); 135 ViewCell::DeriveViewCells(objects, mViewCells, maxViewCells); 136 } 137 138 mBspTree->Construct(mViewCells); 139 break; 140 case BspTree::SCENE_GEOMETRY: 141 Debug << "Construction method: geometry\n"; 142 143 CLEAR_CONTAINER(mViewCells); // we generate new view cells 144 mSceneGraph->CollectObjects(&objects); 145 146 mBspTree->Construct(objects, &mViewCells); 147 break; 148 case BspTree::RAYS: 149 Debug << "Construction method: rays\n"; 150 151 CLEAR_CONTAINER(mViewCells); // we generate new view cells 123 152 124 mBspTree->Construct(mViewCells); 125 break; 126 case BspTree::SCENE_GEOMETRY: 127 CLEAR_CONTAINER(mViewCells); 128 mBspTree->Construct(objects, &mViewCells); 129 break; 130 case BspTree::RAYS: 131 CLEAR_CONTAINER(mViewCells); 132 mBspTree->Construct(objects, &mViewCells); 153 mBspTree->Construct(rays, &mViewCells); 133 154 break; 134 155 default: 156 Debug << "Error: Method not available\n"; 135 157 break; 136 158 } -
trunk/VUT/GtpVisibilityPreprocessor/src/Preprocessor.h
r261 r262 25 25 class Preprocessor { 26 26 public: 27 /** Default constructor initialising e.g., KD tree and BSP tree. 28 */ 29 Preprocessor(); 30 27 31 ~Preprocessor(); 28 32 … … 88 92 /// scene graph loaded from file 89 93 SceneGraph *mSceneGraph; 90 /// BSP tree representing the viewcells 91 BspTree *mViewCellBspTree; 94 92 95 /// kD-tree organizing the scene graph (occluders + occludees) + viewcells 93 96 KdTree *mKdTree; … … 100 103 ViewCellContainer mViewCells; 101 104 102 BspTree * mBspTree; 105 /// BSP tree representing the viewcells 106 BspTree *mBspTree; 103 107 }; 104 108 -
trunk/VUT/GtpVisibilityPreprocessor/src/ViewCell.cpp
r261 r262 11 11 ViewCell::~ViewCell() 12 12 { 13 // NOTE: should I really do this here? 13 // NOTE: should I really do this here? (I know that there is only one mesh per view cell) 14 14 DEL_PTR(mMesh); 15 15 } … … 114 114 // add top vertices 115 115 for (int i = 0; i < 3; ++i) 116 mesh->mVertices.push_back(topTri.mVertices[ 1]);116 mesh->mVertices.push_back(topTri.mVertices[i]); 117 117 118 118 return new ViewCell(mesh); -
trunk/VUT/GtpVisibilityPreprocessor/src/ViewCell.h
r261 r262 67 67 68 68 }; 69 69 70 70 //}; // GtpVisibilityPreprocessor 71 71 -
trunk/VUT/GtpVisibilityPreprocessor/src/ViewCellBsp.cpp
r261 r262 11 11 #include <time.h> 12 12 #include <iomanip> 13 #include "Exporter.h" 13 14 14 15 #define INITIAL_COST 999999// unreachable high initial cost for heuristic evaluation … … 200 201 mRoot(NULL), 201 202 mIsIncremential(false), 202 mStorePolys( false)203 mStorePolys(true) 203 204 { 204 205 Randomize(); // initialise random generator for heuristics … … 279 280 tStack.pop(); 280 281 281 /// if we store 282 if (mStorePolys) 283 Polygon3::DeletePolygons(&node->mPolygons); 282 /// if we stored the polygons 283 CLEAR_CONTAINER(node->mPolygons); 284 284 285 285 if (!node->IsLeaf()) … … 365 365 mTermMaxDepth = maxDepth; 366 366 mStat.nodes = 1; 367 367 368 mBox.Initialize(); // initialise bsp tree bounding box 368 369 } … … 438 439 const int maxPolygons = 0; 439 440 const int maxDepth = 99999; 441 440 442 InitTree(maxPolygons, maxDepth); 441 443 442 443 // tree is completely constructed before444 // view cells are not inserted one after another => better tree behaviour444 // tree is completely constructed once before 445 // view cells are inserted one after another => 446 // global tree optimization possible 445 447 if (!mIsIncremential) 446 448 { 449 Debug << "Not incremential => constructing tree in advance\n"; 447 450 // copy view cell meshes into one big polygon soup 448 451 PolygonContainer *polys = new PolygonContainer(); … … 451 454 // construct tree from viewcell polygons 452 455 Construct(polys); 453 } 454 455 // insert all viewcells 456 457 Export("bsp.x3d"); 458 } 459 460 //-- insert all viewcells 456 461 ViewCellContainer::const_iterator it; 457 462 463 int counter = 0; 464 465 Debug << "View cells insertion...\n"; Debug.flush(); 458 466 for (it = viewCells.begin(); it != viewCells.end(); ++ it) 459 467 { 468 Debug << "Inserting view cell " << ++counter; 460 469 InsertViewCell(*it); 461 470 } 471 Debug << "finished view cells insertion"; 462 472 } 463 473 … … 465 475 void BspTree::Construct(const ObjectContainer &objects, ViewCellContainer *viewCells) 466 476 { 467 #ifdef _DEBUG468 Debug << "Constructing tree using object container\n";469 #endif470 477 // take termination criteria from globals 471 478 InitTree(mTermMaxPolygons, mTermMaxDepth); 472 479 Debug << "HAHAHAHHA";Debug.flush(); 473 480 PolygonContainer *polys = new PolygonContainer(); 474 481 … … 490 497 { 491 498 std::stack<BspTraversalData> tStack; 492 // new root corresponding to unbounded space 493 BspTraversalData tData(new BspLeaf(), mRoot->GetParent(), polys, 0); 499 Debug << "HDDHDH"; Debug.flush(); 500 501 BspTraversalData tData(new BspLeaf(), NULL, polys, 0); 494 502 495 503 tStack.push(tData); 496 504 505 Debug << "Contructing tree using objects..."; Debug.flush(); 497 506 while (!tStack.empty()) 498 507 { … … 500 509 tStack.pop(); 501 510 511 502 512 // subdivide leaf node 503 513 BspNode *root = Subdivide(tStack, tData); 504 514 505 if (!mRoot) // empty tree => new root 515 // empty tree => // new root corresponding to unbounded space 516 if (!mRoot) 506 517 mRoot = root; 507 518 } 519 520 Debug << "finished\n"; 508 521 } 509 522 … … 543 556 } 544 557 558 bool BspTree::ProcessPolygons(PolygonContainer *polys, BspLeaf *leaf) 559 { 560 bool result = false; 561 562 if (mStorePolys) 563 { 564 leaf->AddPolygons(polys); 565 result = true; 566 } 567 else 568 CLEAR_CONTAINER(*polys); 569 570 delete polys; 571 return result; 572 } 573 545 574 BspNode *BspTree::SubdivideNode(BspLeaf *leaf, 546 575 BspInterior *parent, … … 554 583 { 555 584 // add or delete remaining polygons 556 if (mStorePolys) 557 leaf->AddPolygons(polys); 558 else 559 Polygon3::DeletePolygons(polys); 560 561 delete polys; 585 ProcessPolygons(polys, leaf); 562 586 563 587 return leaf; … … 572 596 Debug << node << endl; 573 597 #endif 598 574 599 // split polygon according to current plane 575 600 int splits = 0; … … 795 820 return mStorePolys; 796 821 } 822 797 823 void BspTree::EvaluateLeafStats(const BspTraversalData &data) 798 824 { … … 929 955 } 930 956 957 bool BspTree::Export(const string filename) 958 { 959 Exporter *exporter = Exporter::GetExporter(filename); 960 961 if (exporter) 962 { 963 exporter->ExportBspTree(*this); 964 delete exporter; 965 966 return true; 967 } 968 969 return false; 970 } 931 971 //} // GtpVisibilityPreprocessor -
trunk/VUT/GtpVisibilityPreprocessor/src/ViewCellBsp.h
r261 r262 286 286 bool StorePolys() const; 287 287 288 /** Exports Bsp tree to file. 289 */ 290 bool Export(const string filename); 291 292 288 293 protected: 289 294 … … 386 391 int CastRay(Ray &ray); 387 392 393 /** Discards or stores polygons in leaf and deletes the container. 394 @param polys the polygons 395 @param leaf the leaf where polygons are stored 396 */ 397 bool ProcessPolygons(PolygonContainer *polys, BspLeaf *node); 398 388 399 /// Pointer to the root of the tree 389 400 BspNode *mRoot; -
trunk/VUT/GtpVisibilityPreprocessor/src/X3dExporter.cpp
r261 r262 237 237 238 238 239 //-- create and write indices 239 240 if (mWireframe) 240 241 stream << "<IndexedLineSet ccw=\"TRUE\" coordIndex=\"" << endl; … … 242 243 stream << "<IndexedFaceSet ccw=\"TRUE\" coordIndex=\"" << endl; 243 244 244 VertexContainer::const_iterator vi = poly->mVertices.begin(); 245 245 int index = 0; 246 247 VertexContainer::const_iterator vi; 248 249 for (vi = poly->mVertices.begin(); vi != poly->mVertices.end(); ++vi) 250 { 251 stream << index ++ << " "; 252 } 253 stream << "-1" << endl; 254 255 stream << "\" >" << endl; 256 246 257 stream << "<Coordinate point=\"" << endl; 247 258 248 for ( ; vi != poly->mVertices.end(); ++vi)259 for (vi = poly->mVertices.begin(); vi != poly->mVertices.end(); ++vi) 249 260 { 250 261 stream << (*vi).x << " " << (*vi).y << " " << (*vi).z; … … 252 263 } 253 264 254 stream <<"\" >"<<endl;255 stream <<"</Coordinate>"<<endl;265 stream << "\" >" << endl; 266 stream << "</Coordinate>" << endl; 256 267 257 268 if (mWireframe) … … 303 314 Mesh *mesh = new Mesh; 304 315 305 //AxisAlignedBox3 box = tree.GetBoundingBox();306 //ExportBox(box);316 AxisAlignedBox3 box = tree.GetBoundingBox(); 317 ExportBox(box); 307 318 308 319 while (!tStack.empty()) … … 332 343 { 333 344 BspLeaf *leaf = dynamic_cast<BspLeaf *>(node); 345 334 346 // export view cell geometry 347 335 348 if (!tree.StorePolys() && leaf->GetViewCell()) 349 { 336 350 ExportViewCell(leaf->GetViewCell()); 351 } 352 337 353 } 338 354 } -
trunk/VUT/GtpVisibilityPreprocessor/src/X3dParser.cpp
r261 r262 378 378 379 379 /*********************************************************** 380 * class X3dViewCellsParseHandlers implemenation 380 * class X3dViewCellsParseHandlers implemenation * 381 381 ***********************************************************/ 382 382 … … 421 421 int len = attributes.getLength(); 422 422 int i; 423 423 // clear previous vertex indices 424 mCurrentVertexIndices.clear(); 424 425 for (i=0; i < len; i++) 425 426 { … … 460 461 461 462 VertexContainer vertices; 462 463 463 464 for (int i=0; i < len; i++) 464 465 { … … 498 499 499 500 Vector3 v(x, y, z); 500 vertices.push_back(v); 501 vertices.push_back(v); 501 502 } 502 503 } 503 504 } 504 505 505 506 506 … … 511 511 vertices[mCurrentVertexIndices[i+2]]); 512 512 513 513 // create view cell from base triangle 514 514 const float height = 10; 515 515 mViewCells->push_back(ViewCell::ExtrudeViewCell(baseTri, height)); 516 517 Mesh *mesh = mViewCells->back()->GetMesh(); 518 #ifdef _DEBUG 519 Debug << "Viewcell :" 520 << mesh->mVertices[0] << " " << mesh->mVertices[1] << " " << mesh->mVertices[2] << " " 521 << mesh->mVertices[3] << " " << mesh->mVertices[4] << " " << mesh->mVertices[5] << "\n"; 522 #endif 516 523 } 517 524 } -
trunk/VUT/GtpVisibilityPreprocessor/src/common.h
r261 r262 128 128 129 129 #ifndef DEL_PTR 130 #define DEL_PTR(ptr) while (0) {if (ptr) {delete (ptr); (ptr) = NULL;}} 131 #endif 132 130 #define DEL_PTR(ptr) do {if (ptr) { \ 131 delete (ptr); \ 132 (ptr) = 0;}} \ 133 while (0) 134 #endif 135 // Clears a container (i.e., a vector of pointers) and deletes the pointers 133 136 #ifndef CLEAR_CONTAINER 134 #define CLEAR_CONTAINER(co) while (!co.empty()) {delete co.back(); co.pop_back();} 137 #define CLEAR_CONTAINER(co) do { while (!(co).empty()) { \ 138 DEL_PTR((co).back()); \ 139 (co).pop_back();}} \ 140 while (0) 135 141 #endif 136 142
Note: See TracChangeset
for help on using the changeset viewer.