From d39c333e432263716674559a6aaf1557e43421f0 Mon Sep 17 00:00:00 2001 From: Ben-Bingham Date: Mon, 24 Jun 2024 13:01:37 -0600 Subject: [PATCH] Switched from using SolarSystem Core and SceneFrame to using Universe version --- src/testapp/identifiers.h | 15 ------ src/testapp/scenarios.cpp | 4 +- src/testapp/sessions/solar_system.cpp | 68 ++++++--------------------- 3 files changed, 16 insertions(+), 71 deletions(-) diff --git a/src/testapp/identifiers.h b/src/testapp/identifiers.h index 3170f414..dbf3aebe 100644 --- a/src/testapp/identifiers.h +++ b/src/testapp/identifiers.h @@ -347,21 +347,6 @@ struct PlUniSceneFrame // Solar System sessions -#define TESTAPP_DATA_SOLAR_SYSTEM_CORE 2, \ - idUniverse, tgSolarSystemDeltaTimeIn -struct PlSolarSystemCore -{ - PipelineDef update{ "update - Solar System update" }; - PipelineDef transfer{ "transfer" }; -}; - -#define TESTAPP_DATA_SOLAR_SYSTEM_SCENEFRAME 1, \ - idScnFrame -struct PlSolarSystemSceneFrame -{ - PipelineDef sceneFrame{ "sceneFrame" }; -}; - #define TESTAPP_DATA_SOLAR_SYSTEM_PLANETS 3, \ idPlanetMainSpace, idSatSurfaceSpaces, idCoordNBody diff --git a/src/testapp/scenarios.cpp b/src/testapp/scenarios.cpp index 3056aa98..7032459f 100644 --- a/src/testapp/scenarios.cpp +++ b/src/testapp/scenarios.cpp @@ -469,8 +469,8 @@ static ScenarioMap_t make_scenarios() auto const tgApp = application.get_pipelines< PlApplication >(); - solarSystemCore = setup_solar_system_core(builder, rTopData, tgApp.mainLoop); - solarSystemScnFrame = setup_solar_system_sceneframe(builder, rTopData, solarSystemCore); + solarSystemCore = setup_uni_core(builder, rTopData, tgApp.mainLoop); + solarSystemScnFrame = setup_uni_sceneframe(builder, rTopData, solarSystemCore); solarSystemTestPlanets = setup_solar_system_testplanets(builder, rTopData, solarSystemCore, solarSystemScnFrame); RendererSetupFunc_t const setup_renderer = [](TestApp& rTestApp) diff --git a/src/testapp/sessions/solar_system.cpp b/src/testapp/sessions/solar_system.cpp index c5bc00c7..cc386235 100644 --- a/src/testapp/sessions/solar_system.cpp +++ b/src/testapp/sessions/solar_system.cpp @@ -54,46 +54,6 @@ enum Planets { constexpr unsigned int c_planetCount = 5; -Session setup_solar_system_core( - TopTaskBuilder& rBuilder, - ArrayView topData, - PipelineId const updateOn) -{ - Session out; - OSP_DECLARE_CREATE_DATA_IDS(out, topData, TESTAPP_DATA_SOLAR_SYSTEM_CORE); - - top_emplace< Universe > (topData, idUniverse); - - auto const tgUCore = out.create_pipelines(rBuilder); - - rBuilder.pipeline(tgUCore.update).parent(updateOn);//.wait_for_signal(EStgOptn::ModifyOrSignal); - - rBuilder.pipeline(tgUCore.transfer).parent(tgUCore.update); - - return out; -} // setup_solar_system_core - - -Session setup_solar_system_sceneframe( - TopTaskBuilder& rBuilder, - ArrayView topData, - Session const& solarSystemCore) -{ - auto const tgUCore = solarSystemCore.get_pipelines(); - - Session out; - OSP_DECLARE_CREATE_DATA_IDS(out, topData, TESTAPP_DATA_SOLAR_SYSTEM_SCENEFRAME); - - top_emplace< SceneFrame > (topData, idScnFrame); - - auto const tgUSFrm = out.create_pipelines(rBuilder); - - rBuilder.pipeline(tgUSFrm.sceneFrame).parent(tgUCore.update); - - return out; -} // setup_solar_system_sceneframe - - Session setup_solar_system_testplanets( TopTaskBuilder& rBuilder, ArrayView topData, @@ -103,11 +63,11 @@ Session setup_solar_system_testplanets( using CoSpaceIdVec_t = std::vector; using Corrade::Containers::Array; - OSP_DECLARE_GET_DATA_IDS(solarSystemCore, TESTAPP_DATA_SOLAR_SYSTEM_CORE); - OSP_DECLARE_GET_DATA_IDS(solarSystemScnFrame, TESTAPP_DATA_SOLAR_SYSTEM_SCENEFRAME); + OSP_DECLARE_GET_DATA_IDS(solarSystemCore, TESTAPP_DATA_UNI_CORE); + OSP_DECLARE_GET_DATA_IDS(solarSystemScnFrame, TESTAPP_DATA_UNI_SCENEFRAME); - auto const tgUCore = solarSystemCore .get_pipelines(); - auto const tgUSFrm = solarSystemScnFrame.get_pipelines(); + auto const tgUCore = solarSystemCore .get_pipelines(); + auto const tgUSFrm = solarSystemScnFrame.get_pipelines(); auto &rUniverse = top_get< Universe >(topData, idUniverse); @@ -238,7 +198,7 @@ Session setup_solar_system_testplanets( nBodyView[Planets::ORANGE].mass = 0.0000000001; top_emplace< CoSpaceId >(topData, idPlanetMainSpace, mainSpace); - top_emplace< float >(topData, tgSolarSystemDeltaTimeIn, 1.0f / 60.0f); + top_emplace< float >(topData, tgUniDeltaTimeIn, 1.0f / 60.0f); top_emplace< CoSpaceIdVec_t >(topData, idSatSurfaceSpaces, std::move(satSurfaceSpaces)); // Set initial scene frame @@ -252,13 +212,13 @@ Session setup_solar_system_testplanets( .run_on (tgUCore.update(Run)) .sync_with ({tgUSFrm.sceneFrame(Modify)}) .push_to (out.m_tasks) - .args ({ idUniverse, idPlanetMainSpace, idScnFrame, idSatSurfaceSpaces, tgSolarSystemDeltaTimeIn, idCoordNBody}) - .func([] (Universe& rUniverse, CoSpaceId const planetMainSpace, SceneFrame &rScnFrame, CoSpaceIdVec_t const& rSatSurfaceSpaces, float const solarSystemDeltaTimeIn, osp::KeyedVec& rCoordNBody) noexcept + .args ({ idUniverse, idPlanetMainSpace, idScnFrame, idSatSurfaceSpaces, tgUniDeltaTimeIn, idCoordNBody}) + .func([] (Universe& rUniverse, CoSpaceId const planetMainSpace, SceneFrame &rScnFrame, CoSpaceIdVec_t const& rSatSurfaceSpaces, float const uniDeltaTimeIn, osp::KeyedVec& rCoordNBody) noexcept { CoSpaceCommon &rMainSpaceCommon = rUniverse.m_coordCommon[planetMainSpace]; auto const scale = osp::math::mul_2pow(1.0, -rMainSpaceCommon.m_precision); - double const scaleDelta = solarSystemDeltaTimeIn / scale; + double const scaleDelta = uniDeltaTimeIn / scale; auto const [x, y, z] = sat_views(rMainSpaceCommon.m_satPositions, rMainSpaceCommon.m_data, rMainSpaceCommon.m_satCount); auto const [vx, vy, vz] = sat_views(rMainSpaceCommon.m_satVelocities, rMainSpaceCommon.m_data, rMainSpaceCommon.m_satCount); @@ -287,9 +247,9 @@ Session setup_solar_system_testplanets( Vector3d force = direction * forceMagnitude; Vector3d acceleration = (force / iMass); - vx[i] += acceleration.x() * solarSystemDeltaTimeIn; - vy[i] += acceleration.y() * solarSystemDeltaTimeIn; - vz[i] += acceleration.z() * solarSystemDeltaTimeIn; + vx[i] += acceleration.x() * uniDeltaTimeIn; + vy[i] += acceleration.y() * uniDeltaTimeIn; + vz[i] += acceleration.z() * uniDeltaTimeIn; } } }); @@ -319,14 +279,14 @@ Session setup_solar_system_planets_draw( OSP_DECLARE_GET_DATA_IDS(commonScene, TESTAPP_DATA_COMMON_SCENE); OSP_DECLARE_GET_DATA_IDS(sceneRenderer, TESTAPP_DATA_SCENE_RENDERER); OSP_DECLARE_GET_DATA_IDS(cameraCtrl, TESTAPP_DATA_CAMERA_CTRL); - OSP_DECLARE_GET_DATA_IDS(solarSystemCore, TESTAPP_DATA_SOLAR_SYSTEM_CORE); - OSP_DECLARE_GET_DATA_IDS(solarSystemScnFrame, TESTAPP_DATA_SOLAR_SYSTEM_SCENEFRAME); + OSP_DECLARE_GET_DATA_IDS(solarSystemCore, TESTAPP_DATA_UNI_CORE); + OSP_DECLARE_GET_DATA_IDS(solarSystemScnFrame, TESTAPP_DATA_UNI_SCENEFRAME); OSP_DECLARE_GET_DATA_IDS(solarSystemTestPlanets, TESTAPP_DATA_SOLAR_SYSTEM_PLANETS); auto const tgWin = windowApp .get_pipelines(); auto const tgScnRdr = sceneRenderer .get_pipelines(); auto const tgCmCt = cameraCtrl .get_pipelines(); - auto const tgUSFrm = solarSystemScnFrame.get_pipelines(); + auto const tgUSFrm = solarSystemScnFrame.get_pipelines(); Session out;