Scene::Scene (RTCSceneFlags sflags, RTCAlgorithmFlags aflags) : flags(sflags), aflags(aflags), numMappedBuffers(0), is_build(false), needTriangles(false), needVertices(false), numTriangles(0), numTriangles2(0), numBezierCurves(0), numBezierCurves2(0), numSubdivPatches(0), numSubdivPatches2(0), numUserGeometries1(0), numIntersectionFilters4(0), numIntersectionFilters8(0), numIntersectionFilters16(0), commitCounter(0) { #if !defined(__MIC__) lockstep_scheduler.taskBarrier.init(TaskScheduler::getNumThreads()); #else lockstep_scheduler.taskBarrier.init(MAX_MIC_THREADS); #endif if (g_scene_flags != -1) flags = (RTCSceneFlags) g_scene_flags; geometries.reserve(128); #if defined(__MIC__) accels.add( BVH4mb::BVH4mbTriangle1ObjectSplitBinnedSAH(this) ); accels.add( BVH4i::BVH4iVirtualGeometryBinnedSAH(this) ); accels.add( BVH4Hair::BVH4HairBinnedSAH(this) ); accels.add( BVH4i::BVH4iSubdivMeshBinnedSAH(this) ); if (g_verbose >= 1) { std::cout << "scene flags: static " << isStatic() << " compact = " << isCompact() << " high quality = " << isHighQuality() << " robust = " << isRobust() << std::endl; } if (g_tri_accel == "default" || g_tri_accel == "bvh4i") { if (g_tri_builder == "default") { if (isStatic()) { if (g_verbose >= 1) std::cout << "STATIC BUILDER MODE" << std::endl; if ( isCompact() ) accels.add(BVH4i::BVH4iTriangle1MemoryConservativeBinnedSAH(this)); else if ( isHighQuality() ) accels.add(BVH4i::BVH4iTriangle1ObjectSplitBinnedSAH(this)); else accels.add(BVH4i::BVH4iTriangle1ObjectSplitBinnedSAH(this)); } else { if (g_verbose >= 1) std::cout << "DYNAMIC BUILDER MODE" << std::endl; accels.add(BVH4i::BVH4iTriangle1ObjectSplitMorton(this)); } } else { if (g_tri_builder == "sah" || g_tri_builder == "bvh4i" || g_tri_builder == "bvh4i.sah") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitBinnedSAH(this)); } else if (g_tri_builder == "fast" || g_tri_builder == "morton") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitMorton(this)); } else if (g_tri_builder == "fast_enhanced" || g_tri_builder == "morton.enhanced") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitEnhancedMorton(this)); } else if (g_tri_builder == "high_quality" || g_tri_builder == "presplits") { accels.add(BVH4i::BVH4iTriangle1PreSplitsBinnedSAH(this)); } else if (g_tri_builder == "compact" || g_tri_builder == "memory_conservative") { accels.add(BVH4i::BVH4iTriangle1MemoryConservativeBinnedSAH(this)); } else if (g_tri_builder == "morton64") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitMorton64Bit(this)); } else THROW_RUNTIME_ERROR("unknown builder "+g_tri_builder+" for BVH4i<Triangle1>"); } } else THROW_RUNTIME_ERROR("unknown accel "+g_tri_accel); #else createTriangleAccel(); //accels.add(BVH4::BVH4Triangle1vMB(this)); accels.add(BVH4::BVH4Triangle4vMB(this)); accels.add(BVH4::BVH4UserGeometry(this)); createHairAccel(); accels.add(BVH4::BVH4OBBBezier1iMB(this,false)); createSubdivAccel(); #endif }
Scene::Scene (RTCSceneFlags sflags, RTCAlgorithmFlags aflags) : flags(sflags), aflags(aflags), numMappedBuffers(0), is_build(false), needTriangles(false), needVertices(false), numTriangleMeshes(0), numTriangleMeshes2(0), numTriangles(0), numTriangles2(0), numBezierCurves(0), numBezierCurves2(0), numUserGeometries1(0), numIntersectionFilters4(0), numIntersectionFilters8(0), numIntersectionFilters16(0) { if (g_scene_flags != -1) flags = (RTCSceneFlags) g_scene_flags; geometries.reserve(128); #if defined(__MIC__) accels.add( BVH4mb::BVH4mbTriangle1ObjectSplitBinnedSAH(this) ); accels.add( BVH4i::BVH4iVirtualGeometryBinnedSAH(this) ); accels.add( BVH4Hair::BVH4HairBinnedSAH(this) ); if (g_verbose >= 1) { std::cout << "scene flags: static " << isStatic() << " compact = " << isCompact() << " high quality = " << isHighQuality() << " robust = " << isRobust() << std::endl; } if (g_tri_accel == "default" || g_tri_accel == "bvh4i") { if (g_tri_builder == "default") { if (isStatic()) { if (g_verbose >= 1) std::cout << "STATIC BUILDER MODE" << std::endl; if ( isCompact() ) accels.add(BVH4i::BVH4iTriangle1MemoryConservativeBinnedSAH(this)); else if ( isHighQuality() ) accels.add(BVH4i::BVH4iTriangle1ObjectSplitBinnedSAH(this)); else accels.add(BVH4i::BVH4iTriangle1ObjectSplitBinnedSAH(this)); } else { if (g_verbose >= 1) std::cout << "DYNAMIC BUILDER MODE" << std::endl; accels.add(BVH4i::BVH4iTriangle1ObjectSplitMorton(this)); } } else { if (g_tri_builder == "sah" || g_tri_builder == "bvh4i" || g_tri_builder == "bvh4i.sah") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitBinnedSAH(this)); } else if (g_tri_builder == "fast" || g_tri_builder == "morton") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitMorton(this)); } else if (g_tri_builder == "fast_enhanced" || g_tri_builder == "morton.enhanced") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitEnhancedMorton(this)); } else if (g_tri_builder == "high_quality" || g_tri_builder == "presplits") { accels.add(BVH4i::BVH4iTriangle1PreSplitsBinnedSAH(this)); } else if (g_tri_builder == "compact" || g_tri_builder == "memory_conservative") { accels.add(BVH4i::BVH4iTriangle1MemoryConservativeBinnedSAH(this)); } else if (g_tri_builder == "morton64") { accels.add(BVH4i::BVH4iTriangle1ObjectSplitMorton64Bit(this)); } else throw std::runtime_error("unknown builder "+g_tri_builder+" for BVH4i<Triangle1>"); } } else throw std::runtime_error("unknown accel "+g_tri_accel); #else createTriangleAccel(); accels.add(BVH4MB::BVH4MBTriangle1v(this)); accels.add(BVH4::BVH4UserGeometry(this)); createHairAccel(); #endif }