diff --git a/zenovis/src/optx/RenderEngineOptx.cpp b/zenovis/src/optx/RenderEngineOptx.cpp index 48848fbb7..7e62e9f2c 100644 --- a/zenovis/src/optx/RenderEngineOptx.cpp +++ b/zenovis/src/optx/RenderEngineOptx.cpp @@ -371,7 +371,8 @@ struct GraphicsManager { } } - loadCurveGroup(points, widths, normals, strands, curveTypeEnum, mtlid); + auto abcpath = ud.get2("abcpath_0", "Default"); + loadCurveGroup(points, widths, normals, strands, curveTypeEnum, mtlid, abcpath); return; } @@ -1352,7 +1353,7 @@ struct RenderEngineOptx : RenderEngine, zeno::disable_copy { cachedCurvesMaterials[mtid] = { ctype }; } - for (auto& ele : curveGroupCache) { + for (auto& [key, ele] : curveGroupCache) { auto ctype = ele->curveType; auto mtlid = ele->mtlid; diff --git a/zenovis/xinxinoptix/hair/optixHair.h b/zenovis/xinxinoptix/hair/optixHair.h index 45da54618..e76d78de4 100644 --- a/zenovis/xinxinoptix/hair/optixHair.h +++ b/zenovis/xinxinoptix/hair/optixHair.h @@ -72,6 +72,15 @@ struct HairState // Aux data CurveGroupAux aux {}; + ~HairState() { + cudaFree( reinterpret_cast( aux.strand_u.data ) ); + aux.strand_u.data = 0; + cudaFree( reinterpret_cast( aux.strand_i.data ) ); + aux.strand_i.data = 0; + cudaFree( reinterpret_cast( aux.strand_info.data ) ); + aux.strand_info.data = 0; + } + public: void makeHairGAS(OptixDeviceContext contex); @@ -169,11 +178,11 @@ inline void prepareHairs(OptixDeviceContext context) { } } -inline std::vector> curveGroupCache; -inline std::vector> curveGroupStateCache; +inline std::map> curveGroupCache; +inline std::map> curveGroupStateCache; inline void loadCurveGroup(std::vector& points, std::vector& widths, std::vector& normals, std::vector& strands, - zeno::CurveType curveType, std::string mtlid) { + zeno::CurveType curveType, std::string mtlid, std::string key) { auto cg = std::make_shared(); cg->mtlid = mtlid; @@ -184,14 +193,14 @@ inline void loadCurveGroup(std::vector& points, std::vector& widt cg->normals = std::move(normals); cg->strands = std::move(strands); - curveGroupCache.push_back(cg); + curveGroupCache[key] = cg; } inline void prepareCurveGroup(OptixDeviceContext context) { curveGroupStateCache.clear(); - for (auto& ele : curveGroupCache) { + for (auto& [key, ele] : curveGroupCache) { auto state = std::make_shared(); state->curveGroup = ele; @@ -200,8 +209,7 @@ inline void prepareCurveGroup(OptixDeviceContext context) { state->mtid = ele->mtlid; state->makeCurveGroupGAS(context); - - curveGroupStateCache.push_back(state); + curveGroupStateCache[key] = state; } curveGroupCache.clear(); diff --git a/zenovis/xinxinoptix/optixPathTracer.cpp b/zenovis/xinxinoptix/optixPathTracer.cpp index a328120fd..68a8890f0 100644 --- a/zenovis/xinxinoptix/optixPathTracer.cpp +++ b/zenovis/xinxinoptix/optixPathTracer.cpp @@ -1214,12 +1214,9 @@ void updateRootIAS() } } - for (size_t i=0; icurveType + 3; auto combinedID = ele->mtid + ":" + std::to_string(shader_mark);