state.cpp 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535
  1. // Copyright 2009-2021 Intel Corporation
  2. // SPDX-License-Identifier: Apache-2.0
  3. #include "state.h"
  4. #include "../../common/lexers/streamfilters.h"
  5. namespace embree
  6. {
  7. MutexSys g_printMutex;
  8. State::ErrorHandler State::g_errorHandler;
  9. State::ErrorHandler::ErrorHandler()
  10. : thread_error(createTls()) {}
  11. State::ErrorHandler::~ErrorHandler()
  12. {
  13. Lock<MutexSys> lock(errors_mutex);
  14. for (size_t i=0; i<thread_errors.size(); i++)
  15. delete thread_errors[i];
  16. destroyTls(thread_error);
  17. thread_errors.clear();
  18. }
  19. RTCError* State::ErrorHandler::error()
  20. {
  21. RTCError* stored_error = (RTCError*) getTls(thread_error);
  22. if (stored_error) return stored_error;
  23. Lock<MutexSys> lock(errors_mutex);
  24. stored_error = new RTCError(RTC_ERROR_NONE);
  25. thread_errors.push_back(stored_error);
  26. setTls(thread_error,stored_error);
  27. return stored_error;
  28. }
  29. State::State ()
  30. : enabled_cpu_features(getCPUFeatures()),
  31. enabled_builder_cpu_features(enabled_cpu_features),
  32. frequency_level(FREQUENCY_SIMD256)
  33. {
  34. tri_accel = "default";
  35. tri_builder = "default";
  36. tri_traverser = "default";
  37. tri_accel_mb = "default";
  38. tri_builder_mb = "default";
  39. tri_traverser_mb = "default";
  40. quad_accel = "default";
  41. quad_builder = "default";
  42. quad_traverser = "default";
  43. quad_accel_mb = "default";
  44. quad_builder_mb = "default";
  45. quad_traverser_mb = "default";
  46. line_accel = "default";
  47. line_builder = "default";
  48. line_traverser = "default";
  49. line_accel_mb = "default";
  50. line_builder_mb = "default";
  51. line_traverser_mb = "default";
  52. hair_accel = "default";
  53. hair_builder = "default";
  54. hair_traverser = "default";
  55. hair_accel_mb = "default";
  56. hair_builder_mb = "default";
  57. hair_traverser_mb = "default";
  58. object_accel = "default";
  59. object_builder = "default";
  60. object_accel_min_leaf_size = 1;
  61. object_accel_max_leaf_size = 1;
  62. object_accel_mb = "default";
  63. object_builder_mb = "default";
  64. object_accel_mb_min_leaf_size = 1;
  65. object_accel_mb_max_leaf_size = 1;
  66. max_spatial_split_replications = 1.2f;
  67. useSpatialPreSplits = false;
  68. tessellation_cache_size = 128*1024*1024;
  69. subdiv_accel = "default";
  70. subdiv_accel_mb = "default";
  71. grid_accel = "default";
  72. grid_builder = "default";
  73. grid_accel_mb = "default";
  74. grid_builder_mb = "default";
  75. instancing_open_min = 0;
  76. instancing_block_size = 0;
  77. instancing_open_factor = 8.0f;
  78. instancing_open_max_depth = 32;
  79. instancing_open_max = 50000000;
  80. float_exceptions = false;
  81. quality_flags = -1;
  82. scene_flags = -1;
  83. verbose = 0;
  84. benchmark = 0;
  85. numThreads = 0;
  86. numUserThreads = 0;
  87. #if TASKING_INTERNAL
  88. set_affinity = true;
  89. #else
  90. set_affinity = false;
  91. #endif
  92. start_threads = false;
  93. enable_selockmemoryprivilege = false;
  94. #if defined(__LINUX__)
  95. hugepages = true;
  96. #else
  97. hugepages = false;
  98. #endif
  99. hugepages_success = true;
  100. alloc_main_block_size = 0;
  101. alloc_num_main_slots = 0;
  102. alloc_thread_block_size = 0;
  103. alloc_single_thread_alloc = -1;
  104. error_function = nullptr;
  105. error_function_userptr = nullptr;
  106. memory_monitor_function = nullptr;
  107. memory_monitor_userptr = nullptr;
  108. }
  109. State::~State() {
  110. }
  111. bool State::hasISA(const int isa) {
  112. return (enabled_cpu_features & isa) == isa;
  113. }
  114. bool State::checkISASupport() {
  115. #if defined(__ARM_NEON)
  116. /*
  117. * NEON CPU type is a mixture of NEON and SSE2
  118. */
  119. bool hasSSE2 = (getCPUFeatures() & enabled_cpu_features) & CPU_FEATURE_SSE2;
  120. /* this will be true when explicitly initialize Device with `isa=neon` config */
  121. bool hasNEON = (getCPUFeatures() & enabled_cpu_features) & CPU_FEATURE_NEON;
  122. return hasSSE2 || hasNEON;
  123. #else
  124. return (getCPUFeatures() & enabled_cpu_features) == enabled_cpu_features;
  125. #endif
  126. }
  127. void State::verify()
  128. {
  129. /* verify that calculations stay in range */
  130. assert(rcp(min_rcp_input)*FLT_LARGE+FLT_LARGE < 0.01f*FLT_MAX);
  131. /* here we verify that CPP files compiled for a specific ISA only
  132. * call that same or lower ISA version of non-inlined class member
  133. * functions */
  134. #if defined(DEBUG)
  135. #if defined(EMBREE_TARGET_SSE2)
  136. #if !defined(__ARM_NEON)
  137. assert(sse2::getISA() <= SSE2);
  138. #endif
  139. #endif
  140. #if defined(EMBREE_TARGET_SSE42)
  141. assert(sse42::getISA() <= SSE42);
  142. #endif
  143. #if defined(EMBREE_TARGET_AVX)
  144. assert(avx::getISA() <= AVX);
  145. #endif
  146. #if defined(EMBREE_TARGET_AVX2)
  147. assert(avx2::getISA() <= AVX2);
  148. #endif
  149. #if defined (EMBREE_TARGET_AVX512)
  150. assert(avx512::getISA() <= AVX512);
  151. #endif
  152. #endif
  153. }
  154. const char* symbols[3] = { "=", ",", "|" };
  155. bool State::parseFile(const FileName& fileName)
  156. {
  157. FILE* f = fopen(fileName.c_str(),"r");
  158. if (!f) return false;
  159. Ref<Stream<int> > file = new FileStream(f,fileName);
  160. std::vector<std::string> syms;
  161. for (size_t i=0; i<sizeof(symbols)/sizeof(void*); i++)
  162. syms.push_back(symbols[i]);
  163. Ref<TokenStream> cin = new TokenStream(new LineCommentFilter(file,"#"),
  164. TokenStream::alpha+TokenStream::ALPHA+TokenStream::numbers+"_.",
  165. TokenStream::separators,syms);
  166. parse(cin);
  167. return true;
  168. }
  169. void State::parseString(const char* cfg)
  170. {
  171. if (cfg == nullptr) return;
  172. std::vector<std::string> syms;
  173. for (size_t i=0; i<sizeof(symbols)/sizeof(void*); i++)
  174. syms.push_back(symbols[i]);
  175. Ref<TokenStream> cin = new TokenStream(new StrStream(cfg),
  176. TokenStream::alpha+TokenStream::ALPHA+TokenStream::numbers+"_.",
  177. TokenStream::separators,syms);
  178. parse(cin);
  179. }
  180. int string_to_cpufeatures(const std::string& isa)
  181. {
  182. if (isa == "sse" ) return SSE;
  183. else if (isa == "sse2") return SSE2;
  184. else if (isa == "sse3") return SSE3;
  185. else if (isa == "ssse3") return SSSE3;
  186. else if (isa == "sse41") return SSE41;
  187. else if (isa == "sse4.1") return SSE41;
  188. else if (isa == "sse42") return SSE42;
  189. else if (isa == "sse4.2") return SSE42;
  190. else if (isa == "avx") return AVX;
  191. else if (isa == "avxi") return AVXI;
  192. else if (isa == "avx2") return AVX2;
  193. else if (isa == "avx512") return AVX512;
  194. else return SSE2;
  195. }
  196. void State::parse(Ref<TokenStream> cin)
  197. {
  198. /* parse until end of stream */
  199. while (cin->peek() != Token::Eof())
  200. {
  201. const Token tok = cin->get();
  202. if (tok == Token::Id("threads") && cin->trySymbol("="))
  203. numThreads = cin->get().Int();
  204. else if (tok == Token::Id("user_threads")&& cin->trySymbol("="))
  205. numUserThreads = cin->get().Int();
  206. else if (tok == Token::Id("set_affinity")&& cin->trySymbol("="))
  207. set_affinity = cin->get().Int();
  208. else if (tok == Token::Id("affinity")&& cin->trySymbol("="))
  209. set_affinity = cin->get().Int();
  210. else if (tok == Token::Id("start_threads")&& cin->trySymbol("="))
  211. start_threads = cin->get().Int();
  212. else if (tok == Token::Id("isa") && cin->trySymbol("=")) {
  213. std::string isa_str = toLowerCase(cin->get().Identifier());
  214. enabled_cpu_features = string_to_cpufeatures(isa_str);
  215. enabled_builder_cpu_features = enabled_cpu_features;
  216. }
  217. else if (tok == Token::Id("max_isa") && cin->trySymbol("=")) {
  218. std::string isa_str = toLowerCase(cin->get().Identifier());
  219. enabled_cpu_features &= string_to_cpufeatures(isa_str);
  220. enabled_builder_cpu_features &= enabled_cpu_features;
  221. }
  222. else if (tok == Token::Id("max_builder_isa") && cin->trySymbol("=")) {
  223. std::string isa_str = toLowerCase(cin->get().Identifier());
  224. enabled_builder_cpu_features &= string_to_cpufeatures(isa_str);
  225. }
  226. else if (tok == Token::Id("frequency_level") && cin->trySymbol("=")) {
  227. std::string freq = cin->get().Identifier();
  228. if (freq == "simd128") frequency_level = FREQUENCY_SIMD128;
  229. else if (freq == "simd256") frequency_level = FREQUENCY_SIMD256;
  230. else if (freq == "simd512") frequency_level = FREQUENCY_SIMD512;
  231. }
  232. else if (tok == Token::Id("enable_selockmemoryprivilege") && cin->trySymbol("=")) {
  233. enable_selockmemoryprivilege = cin->get().Int();
  234. }
  235. else if (tok == Token::Id("hugepages") && cin->trySymbol("=")) {
  236. hugepages = cin->get().Int();
  237. }
  238. else if (tok == Token::Id("float_exceptions") && cin->trySymbol("="))
  239. float_exceptions = cin->get().Int();
  240. else if ((tok == Token::Id("tri_accel") || tok == Token::Id("accel")) && cin->trySymbol("="))
  241. tri_accel = cin->get().Identifier();
  242. else if ((tok == Token::Id("tri_builder") || tok == Token::Id("builder")) && cin->trySymbol("="))
  243. tri_builder = cin->get().Identifier();
  244. else if ((tok == Token::Id("tri_traverser") || tok == Token::Id("traverser")) && cin->trySymbol("="))
  245. tri_traverser = cin->get().Identifier();
  246. else if ((tok == Token::Id("tri_accel_mb") || tok == Token::Id("accel_mb")) && cin->trySymbol("="))
  247. tri_accel_mb = cin->get().Identifier();
  248. else if ((tok == Token::Id("tri_builder_mb") || tok == Token::Id("builder_mb")) && cin->trySymbol("="))
  249. tri_builder_mb = cin->get().Identifier();
  250. else if ((tok == Token::Id("tri_traverser_mb") || tok == Token::Id("traverser_mb")) && cin->trySymbol("="))
  251. tri_traverser_mb = cin->get().Identifier();
  252. else if ((tok == Token::Id("quad_accel")) && cin->trySymbol("="))
  253. quad_accel = cin->get().Identifier();
  254. else if ((tok == Token::Id("quad_builder")) && cin->trySymbol("="))
  255. quad_builder = cin->get().Identifier();
  256. else if ((tok == Token::Id("quad_traverser")) && cin->trySymbol("="))
  257. quad_traverser = cin->get().Identifier();
  258. else if ((tok == Token::Id("quad_accel_mb")) && cin->trySymbol("="))
  259. quad_accel_mb = cin->get().Identifier();
  260. else if ((tok == Token::Id("quad_builder_mb")) && cin->trySymbol("="))
  261. quad_builder_mb = cin->get().Identifier();
  262. else if ((tok == Token::Id("quad_traverser_mb")) && cin->trySymbol("="))
  263. quad_traverser_mb = cin->get().Identifier();
  264. else if ((tok == Token::Id("line_accel")) && cin->trySymbol("="))
  265. line_accel = cin->get().Identifier();
  266. else if ((tok == Token::Id("line_builder")) && cin->trySymbol("="))
  267. line_builder = cin->get().Identifier();
  268. else if ((tok == Token::Id("line_traverser")) && cin->trySymbol("="))
  269. line_traverser = cin->get().Identifier();
  270. else if ((tok == Token::Id("line_accel_mb")) && cin->trySymbol("="))
  271. line_accel_mb = cin->get().Identifier();
  272. else if ((tok == Token::Id("line_builder_mb")) && cin->trySymbol("="))
  273. line_builder_mb = cin->get().Identifier();
  274. else if ((tok == Token::Id("line_traverser_mb")) && cin->trySymbol("="))
  275. line_traverser_mb = cin->get().Identifier();
  276. else if (tok == Token::Id("hair_accel") && cin->trySymbol("="))
  277. hair_accel = cin->get().Identifier();
  278. else if (tok == Token::Id("hair_builder") && cin->trySymbol("="))
  279. hair_builder = cin->get().Identifier();
  280. else if (tok == Token::Id("hair_traverser") && cin->trySymbol("="))
  281. hair_traverser = cin->get().Identifier();
  282. else if (tok == Token::Id("hair_accel_mb") && cin->trySymbol("="))
  283. hair_accel_mb = cin->get().Identifier();
  284. else if (tok == Token::Id("hair_builder_mb") && cin->trySymbol("="))
  285. hair_builder_mb = cin->get().Identifier();
  286. else if (tok == Token::Id("hair_traverser_mb") && cin->trySymbol("="))
  287. hair_traverser_mb = cin->get().Identifier();
  288. else if (tok == Token::Id("object_accel") && cin->trySymbol("="))
  289. object_accel = cin->get().Identifier();
  290. else if (tok == Token::Id("object_builder") && cin->trySymbol("="))
  291. object_builder = cin->get().Identifier();
  292. else if (tok == Token::Id("object_accel_min_leaf_size") && cin->trySymbol("="))
  293. object_accel_min_leaf_size = cin->get().Int();
  294. else if (tok == Token::Id("object_accel_max_leaf_size") && cin->trySymbol("="))
  295. object_accel_max_leaf_size = cin->get().Int();
  296. else if (tok == Token::Id("object_accel_mb") && cin->trySymbol("="))
  297. object_accel_mb = cin->get().Identifier();
  298. else if (tok == Token::Id("object_builder_mb") && cin->trySymbol("="))
  299. object_builder_mb = cin->get().Identifier();
  300. else if (tok == Token::Id("object_accel_mb_min_leaf_size") && cin->trySymbol("="))
  301. object_accel_mb_min_leaf_size = cin->get().Int();
  302. else if (tok == Token::Id("object_accel_mb_max_leaf_size") && cin->trySymbol("="))
  303. object_accel_mb_max_leaf_size = cin->get().Int();
  304. else if (tok == Token::Id("instancing_open_min") && cin->trySymbol("="))
  305. instancing_open_min = cin->get().Int();
  306. else if (tok == Token::Id("instancing_block_size") && cin->trySymbol("=")) {
  307. instancing_block_size = cin->get().Int();
  308. instancing_open_factor = 0.0f;
  309. }
  310. else if (tok == Token::Id("instancing_open_max_depth") && cin->trySymbol("="))
  311. instancing_open_max_depth = cin->get().Int();
  312. else if (tok == Token::Id("instancing_open_factor") && cin->trySymbol("=")) {
  313. instancing_block_size = 0;
  314. instancing_open_factor = cin->get().Float();
  315. }
  316. else if (tok == Token::Id("instancing_open_max") && cin->trySymbol("="))
  317. instancing_open_max = cin->get().Int();
  318. else if (tok == Token::Id("subdiv_accel") && cin->trySymbol("="))
  319. subdiv_accel = cin->get().Identifier();
  320. else if (tok == Token::Id("subdiv_accel_mb") && cin->trySymbol("="))
  321. subdiv_accel_mb = cin->get().Identifier();
  322. else if (tok == Token::Id("grid_accel") && cin->trySymbol("="))
  323. grid_accel = cin->get().Identifier();
  324. else if (tok == Token::Id("grid_accel_mb") && cin->trySymbol("="))
  325. grid_accel_mb = cin->get().Identifier();
  326. else if (tok == Token::Id("verbose") && cin->trySymbol("="))
  327. verbose = cin->get().Int();
  328. else if (tok == Token::Id("benchmark") && cin->trySymbol("="))
  329. benchmark = cin->get().Int();
  330. else if (tok == Token::Id("quality")) {
  331. if (cin->trySymbol("=")) {
  332. Token flag = cin->get();
  333. if (flag == Token::Id("low")) quality_flags = RTC_BUILD_QUALITY_LOW;
  334. else if (flag == Token::Id("medium")) quality_flags = RTC_BUILD_QUALITY_MEDIUM;
  335. else if (flag == Token::Id("high")) quality_flags = RTC_BUILD_QUALITY_HIGH;
  336. }
  337. }
  338. else if (tok == Token::Id("scene_flags")) {
  339. scene_flags = 0;
  340. if (cin->trySymbol("=")) {
  341. do {
  342. Token flag = cin->get();
  343. if (flag == Token::Id("dynamic") ) scene_flags |= RTC_SCENE_FLAG_DYNAMIC;
  344. else if (flag == Token::Id("compact")) scene_flags |= RTC_SCENE_FLAG_COMPACT;
  345. else if (flag == Token::Id("robust")) scene_flags |= RTC_SCENE_FLAG_ROBUST;
  346. } while (cin->trySymbol("|"));
  347. }
  348. }
  349. else if (tok == Token::Id("max_spatial_split_replications") && cin->trySymbol("="))
  350. max_spatial_split_replications = cin->get().Float();
  351. else if (tok == Token::Id("presplits") && cin->trySymbol("="))
  352. useSpatialPreSplits = cin->get().Int() != 0 ? true : false;
  353. else if (tok == Token::Id("tessellation_cache_size") && cin->trySymbol("="))
  354. tessellation_cache_size = size_t(cin->get().Float()*1024.0f*1024.0f);
  355. else if (tok == Token::Id("cache_size") && cin->trySymbol("="))
  356. tessellation_cache_size = size_t(cin->get().Float()*1024.0f*1024.0f);
  357. else if (tok == Token::Id("alloc_main_block_size") && cin->trySymbol("="))
  358. alloc_main_block_size = cin->get().Int();
  359. else if (tok == Token::Id("alloc_num_main_slots") && cin->trySymbol("="))
  360. alloc_num_main_slots = cin->get().Int();
  361. else if (tok == Token::Id("alloc_thread_block_size") && cin->trySymbol("="))
  362. alloc_thread_block_size = cin->get().Int();
  363. else if (tok == Token::Id("alloc_single_thread_alloc") && cin->trySymbol("="))
  364. alloc_single_thread_alloc = cin->get().Int();
  365. cin->trySymbol(","); // optional , separator
  366. }
  367. }
  368. bool State::verbosity(size_t N) {
  369. return N <= verbose;
  370. }
  371. void State::print()
  372. {
  373. std::cout << "general:" << std::endl;
  374. std::cout << " build threads = " << numThreads << std::endl;
  375. std::cout << " build user threads = " << numUserThreads << std::endl;
  376. std::cout << " start_threads = " << start_threads << std::endl;
  377. std::cout << " affinity = " << set_affinity << std::endl;
  378. std::cout << " frequency_level = ";
  379. switch (frequency_level) {
  380. case FREQUENCY_SIMD128: std::cout << "simd128" << std::endl; break;
  381. case FREQUENCY_SIMD256: std::cout << "simd256" << std::endl; break;
  382. case FREQUENCY_SIMD512: std::cout << "simd512" << std::endl; break;
  383. default: std::cout << "error" << std::endl; break;
  384. }
  385. std::cout << " hugepages = ";
  386. if (!hugepages) std::cout << "disabled" << std::endl;
  387. else if (hugepages_success) std::cout << "enabled" << std::endl;
  388. else std::cout << "failed" << std::endl;
  389. std::cout << " verbosity = " << verbose << std::endl;
  390. std::cout << " cache_size = " << float(tessellation_cache_size)*1E-6 << " MB" << std::endl;
  391. std::cout << " max_spatial_split_replications = " << max_spatial_split_replications << std::endl;
  392. std::cout << "triangles:" << std::endl;
  393. std::cout << " accel = " << tri_accel << std::endl;
  394. std::cout << " builder = " << tri_builder << std::endl;
  395. std::cout << " traverser = " << tri_traverser << std::endl;
  396. std::cout << "motion blur triangles:" << std::endl;
  397. std::cout << " accel = " << tri_accel_mb << std::endl;
  398. std::cout << " builder = " << tri_builder_mb << std::endl;
  399. std::cout << " traverser = " << tri_traverser_mb << std::endl;
  400. std::cout << "quads:" << std::endl;
  401. std::cout << " accel = " << quad_accel << std::endl;
  402. std::cout << " builder = " << quad_builder << std::endl;
  403. std::cout << " traverser = " << quad_traverser << std::endl;
  404. std::cout << "motion blur quads:" << std::endl;
  405. std::cout << " accel = " << quad_accel_mb << std::endl;
  406. std::cout << " builder = " << quad_builder_mb << std::endl;
  407. std::cout << " traverser = " << quad_traverser_mb << std::endl;
  408. std::cout << "line segments:" << std::endl;
  409. std::cout << " accel = " << line_accel << std::endl;
  410. std::cout << " builder = " << line_builder << std::endl;
  411. std::cout << " traverser = " << line_traverser << std::endl;
  412. std::cout << "motion blur line segments:" << std::endl;
  413. std::cout << " accel = " << line_accel_mb << std::endl;
  414. std::cout << " builder = " << line_builder_mb << std::endl;
  415. std::cout << " traverser = " << line_traverser_mb << std::endl;
  416. std::cout << "hair:" << std::endl;
  417. std::cout << " accel = " << hair_accel << std::endl;
  418. std::cout << " builder = " << hair_builder << std::endl;
  419. std::cout << " traverser = " << hair_traverser << std::endl;
  420. std::cout << "motion blur hair:" << std::endl;
  421. std::cout << " accel = " << hair_accel_mb << std::endl;
  422. std::cout << " builder = " << hair_builder_mb << std::endl;
  423. std::cout << " traverser = " << hair_traverser_mb << std::endl;
  424. std::cout << "subdivision surfaces:" << std::endl;
  425. std::cout << " accel = " << subdiv_accel << std::endl;
  426. std::cout << "grids:" << std::endl;
  427. std::cout << " accel = " << grid_accel << std::endl;
  428. std::cout << " builder = " << grid_builder << std::endl;
  429. std::cout << "motion blur grids:" << std::endl;
  430. std::cout << " accel = " << grid_accel_mb << std::endl;
  431. std::cout << " builder = " << grid_builder_mb << std::endl;
  432. std::cout << "object_accel:" << std::endl;
  433. std::cout << " min_leaf_size = " << object_accel_min_leaf_size << std::endl;
  434. std::cout << " max_leaf_size = " << object_accel_max_leaf_size << std::endl;
  435. std::cout << "object_accel_mb:" << std::endl;
  436. std::cout << " min_leaf_size = " << object_accel_mb_min_leaf_size << std::endl;
  437. std::cout << " max_leaf_size = " << object_accel_mb_max_leaf_size << std::endl;
  438. }
  439. }