Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support surface-based VecGeom 2.x navigator #1422

Draft
wants to merge 53 commits into
base: develop
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
2cb9b11
Adapt to VG 2.x templated ABBoxManager
mrguilima Sep 16, 2024
ef6eec4
Updates to use the latest BVHSurfNavigator from VecGeom 2.x
mrguilima Sep 20, 2024
6fa1b18
Temporary fix to four-levels.gdml: replace unsupported orb with suppo…
mrguilima Sep 18, 2024
228ed58
Fixes to Vecgeom:FourLevelsTest*
mrguilima Sep 18, 2024
9956e5d
Revert "Fixes to Vecgeom:FourLevelsTest*"
sethrj Sep 23, 2024
5265793
Add orb->sphere translation and disable unimplemented surface solids
sethrj Sep 23, 2024
0c943b7
Add surface geometry to CI
sethrj Sep 24, 2024
f272247
Merge remote-tracking branch 'upstream/develop' into vg-2.x
sethrj Sep 24, 2024
94eba34
REVERTME: delete other CI builds
sethrj Sep 24, 2024
97be3f7
Fix infinite loop in field propagator due to misbehaving boundary
sethrj Sep 25, 2024
162bfa2
Simplify initializer
sethrj Sep 25, 2024
f4ce1c8
Add two-boxes test and re-enable other vecgeom tests
sethrj Sep 25, 2024
6d7acf4
Fix distance-to-boundary by initializing hit surface to -1
sethrj Sep 25, 2024
161823a
Fix SurfNavigator for TwoBoxes*: new field, VecgeomTrackView::hit_surf_
mrguilima Oct 2, 2024
8682d4b
Merge remote-tracking branch 'upstream/develop' into vg-2.x
sethrj Oct 7, 2024
a64570c
Revert orb-to-sphere conversion after vecgeom#1231
sethrj Sep 25, 2024
88e4716
Always save cache if build succeeds
sethrj Oct 8, 2024
a0f38b2
fixup! Always save cache if build succeeds
sethrj Oct 8, 2024
f9d8fb0
New reference values for CmseTest.trace
mrguilima Oct 6, 2024
f29529d
Always reset hit_surf before calling finding next step
mrguilima Oct 10, 2024
69a1de2
No more warnings during loading of four-levels geometry
mrguilima Oct 10, 2024
f75b87b
No more warnings during loading of Cmse.gdml
mrguilima Oct 10, 2024
976089d
Add CELERITAS_VECGEOM_SURFACE macro
sethrj Oct 15, 2024
3b0385b
Make next surface persistent
sethrj Oct 15, 2024
e45bc55
Loosen move-internal requirement for VecGeom
sethrj Oct 15, 2024
137ae12
Remove warning expectation from vecgeom 2
sethrj Oct 15, 2024
4eeed43
Fix build
sethrj Oct 15, 2024
a107ae9
Disabled two tests doing tracking outside of world
mrguilima Oct 15, 2024
b9cbe7f
GL temp: missing code
mrguilima Oct 15, 2024
9426140
Merge branch 'develop' into vg-2.x
mrguilima Oct 23, 2024
a85bc2f
Disable tests related to navigation from the outside
mrguilima Oct 14, 2024
39941c0
Fixes for VecGeom v2.x
mrguilima Oct 29, 2024
970100b
Switch test expected value depending on VecGeom version
mrguilima Nov 4, 2024
7f9b580
More temporary fixes to Vecgeom tests
mrguilima Nov 5, 2024
ce5ec00
Merge branch 'develop' into vg-2.x
mrguilima Nov 5, 2024
b7a5aaa
Merge branch 'develop' into vg-2.x
mrguilima Nov 7, 2024
45a279b
Extend CMake version to 3.31 and delay action on new CMP0175
mrguilima Dec 23, 2024
53e646a
Fix expected volumes and safety values in Vecgeom.test.cc
mrguilima Dec 23, 2024
cecc7fc
Merge branch 'develop' into vg-2.x
mrguilima Dec 23, 2024
6451bfc
Fix test Geometry:CmseTest*
mrguilima Dec 23, 2024
66ac5cc
Fix Geometry test
mrguilima Dec 23, 2024
7c66af4
Add Solids tests based on solids model rather than VecGeom version
mrguilima Jan 3, 2025
1b312b8
Use BVHNavigator from VecGeom since VecGeom 2.0
mrguilima Jan 3, 2025
79bdab6
Adjust Vecgeom.test.cc expectations based on VecGeom version
mrguilima Jan 3, 2025
dd314ae
Extend CMake version to 3.31 and delay action on new CMP0175
mrguilima Dec 23, 2024
b026ac7
Fix expected volumes and safety values in Vecgeom.test.cc
mrguilima Dec 23, 2024
02543a0
Merge branch 'temp3' into vg-2.x
mrguilima Jan 3, 2025
7848057
Fix SolidsGeantTest*
mrguilima Jan 3, 2025
5030b88
Use VecGeom ABBoxManager alias when available
mrguilima Jan 4, 2025
2e1f256
Fix leftover from a merge conflict
mrguilima Jan 4, 2025
ccc4677
Avoid lots of tests in VecGeom surface model, until they get fixed
mrguilima Jan 4, 2025
a687140
Revert "Fix infinite loop in field propagator due to misbehaving boun…
mrguilima Jan 8, 2025
b153b54
Merge branch 'develop' into vg-2.x
mrguilima Jan 10, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
55 changes: 42 additions & 13 deletions .github/workflows/build-spack.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,17 +31,8 @@ jobs:
special: [null]
geant: ["10.5", "10.6", "10.7", "11.0", "11.1", "11.2", "11.3"]
include:
- geometry: "orange"
special: "minimal"
geant: null
- geometry: "orange"
special: "float"
geant: "11.0"
- geometry: "orange"
special: "asanlite"
geant: null
- geometry: "vecgeom"
special: "clhep"
special: "vgsurf"
geant: "11.0"
- geometry: "geant4"
special: null
Expand Down Expand Up @@ -132,8 +123,8 @@ jobs:
echo "${SPACK_VIEW}/bin" >> $GITHUB_PATH
echo "CMAKE_PREFIX_PATH=${SPACK_VIEW}:${CMAKE_PREFIX_PATH}" >> $GITHUB_ENV
spack env activate . --sh > "${SPACK_VIEW}/rc"
- name: Cache ccache
uses: actions/cache@v4
- name: Restore ccache
uses: actions/cache/restore@v4
with:
path: ${{env.CCACHE_DIR}}
key: ccache-${{env.CMAKE_PRESET}}-${{matrix.geant}}-${{github.run_id}}
Expand All @@ -143,6 +134,33 @@ jobs:
- name: Zero ccache stats
run: |
ccache -z
- name: Install VecGeom surface
if: ${{matrix.geometry == 'vecgeom' && matrix.special == 'vgsurf'}}
run: |
. ${SPACK_VIEW}/rc
git clone -b surface_model --depth=368 \
https://gitlab.cern.ch/VecGeom/VecGeom.git vecgeom
cd vecgeom
mkdir build
cd build
export VECGEOM_PREFIX_PATH=$GITHUB_WORKSPACE/vecgeom/install
cmake \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_CXX_COMPILER_LAUNCHER=ccache \
-DCMAKE_CXX_STANDARD:STRING=17 \
-DVECGEOM_BACKEND:STRING=Scalar -DVECGEOM_VECTOR:STRING=empty \
-DVECGEOM_BUILTIN_VECCORE:BOOL=ON \
-DVECGEOM_NO_SPECIALIZATION:BOOL=ON \
-DVECGEOM_USE_SURF:BOOL=ON -DVECGEOM_USE_NAVTUPLE:BOOL=OFF -DVECGEOM_USE_NAVINDEX:BOOL=ON \
-DBUILD_SHARED_LIBS:BOOL=ON \
-DVECGEOM_GDML:BOOL=ON -DVECGEOM_ENABLE_CUDA:BOOL=OFF -DVECGEOM_GEANT4:BOOL=OFF -DVECGEOM_ROOT:BOOL=OFF \
-DBUILD_TESTING:BOOL=OFF \
-DCMAKE_INSTALL_PREFIX:STRING=$VECGEOM_PREFIX_PATH \
-G Ninja \
..
ninja install
echo "CMAKE_PREFIX_PATH=${CMAKE_PREFIX_PATH}:${VECGEOM_PREFIX_PATH}" >> $GITHUB_ENV
echo "LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:${VECGEOM_PREFIX_PATH}/lib" >> $GITHUB_ENV
- name: Configure Celeritas
run: |
ln -fs scripts/cmake-presets/ci-ubuntu-github.json CMakeUserPresets.json
Expand Down Expand Up @@ -188,9 +206,20 @@ jobs:
if: ${{matrix.special != 'clang-tidy'}}
working-directory: build
run: |
ninja -v -k0
- name: Save ccache
if: ${{always() && steps.build.outcome == 'success'}}
uses: actions/cache/save@v4
with:
path: ${{env.CCACHE_DIR}}
key: ccache-${{env.CMAKE_PRESET}}-${{matrix.geant}}-${{github.run_id}}
ninja -v -k0
- name: Regenerate ROOT test data
if: ${{matrix.geant == '11.0'}}
if: ${{
matrix.geant == '11.0'
&& matrix.special != 'minimal'
&& matrix.special != 'vgsurf'
}}
working-directory: build
run: |
ninja -v -k0 update-root-test-data
Expand Down
1 change: 0 additions & 1 deletion .github/workflows/pull_request.yml
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,6 @@ jobs:
needs: [all-prechecks]
uses: ./.github/workflows/build-docker.yml
build-spack:
needs: [all-prechecks]
uses: ./.github/workflows/build-spack.yml

# Specifying a dependent job allows us to select a single "requires" check in the project GitHub settings
Expand Down
8 changes: 8 additions & 0 deletions scripts/cmake-presets/ci-ubuntu-github.json
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,14 @@
"cacheVariables": {
}
},
{
"name": "reldeb-vecgeom-vgsurf",
"description": "Build with release, assertions, VecGeom",
"inherits": ["reldeb-vecgeom"],
"cacheVariables": {
"CELERITAS_USE_ROOT": {"type": "BOOL", "value": "OFF"}
}
},
{
"name": "ndebug-vecgeom",
"description": "Build release with vecgeom for testing *only* demos",
Expand Down
13 changes: 13 additions & 0 deletions src/corecel/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,19 @@ foreach(_dep Geant4 VecGeom HepMC3)
endforeach()
list(JOIN CELERITAS_DEPENDENCY_VERSIONS "\n" CELERITAS_DEPENDENCY_VERSIONS)

# Save
if(CELERITAS_USE_VecGeom)
if(VecGeom_USE_SURF)
set(_surf_geo 1)
else()
set(_surf_geo 0)
endif()
set(CELERITAS_VECGEOM_SURFACE_DEF
"#define CELERITAS_VECGEOM_SURFACE ${_surf_geo}"
)
else()
set(CELERITAS_VECGEOM_SURFACE_DEF "/* #undef CELERITAS_VECGEOM_SURFACE */")
endif()
#-----------------------------------------------------------------------------#

celeritas_configure_file("Version.hh.in" "corecel/Version.hh" @ONLY)
Expand Down
2 changes: 2 additions & 0 deletions src/corecel/Config.hh.in
Original file line number Diff line number Diff line change
Expand Up @@ -60,3 +60,5 @@
@CELERITAS_SINCOSPI_PREFIX_DEF@

@CELERITAS_DEPENDENCY_VERSIONS@

@CELERITAS_VECGEOM_SURFACE_DEF@
8 changes: 8 additions & 0 deletions src/geocel/g4vg/SolidConverter.cc
Original file line number Diff line number Diff line change
Expand Up @@ -176,17 +176,25 @@ auto SolidConverter::convert_impl(arg_type solid_base) -> result_type
VGSC_TYPE_FUNC(Box , box),
VGSC_TYPE_FUNC(Cons , cons),
VGSC_TYPE_FUNC(CutTubs , cuttubs),
#ifndef VECGEOM_USE_SURF
VGSC_TYPE_FUNC(Ellipsoid , ellipsoid),
VGSC_TYPE_FUNC(EllipticalCone , ellipticalcone),
VGSC_TYPE_FUNC(EllipticalTube , ellipticaltube),
#endif
VGSC_TYPE_FUNC(ExtrudedSolid , extrudedsolid),
#ifndef VECGEOM_USE_SURF
VGSC_TYPE_FUNC(GenericPolycone , genericpolycone),
#endif
VGSC_TYPE_FUNC(GenericTrap , generictrap),
#ifndef VECGEOM_USE_SURF
VGSC_TYPE_FUNC(Hype , hype),
#endif
VGSC_TYPE_FUNC(IntersectionSolid, intersectionsolid),
VGSC_TYPE_FUNC(Orb , orb),
VGSC_TYPE_FUNC(Para , para),
#ifndef VECGEOM_USE_SURF
VGSC_TYPE_FUNC(Paraboloid , paraboloid),
#endif
VGSC_TYPE_FUNC(Polycone , polycone),
VGSC_TYPE_FUNC(Polyhedra , polyhedra),
VGSC_TYPE_FUNC(ReflectedSolid , reflectedsolid),
Expand Down
19 changes: 16 additions & 3 deletions src/geocel/vg/VecgeomData.hh
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,10 @@
//---------------------------------------------------------------------------//
#pragma once

#include "corecel/Config.hh"

#include "corecel/Macros.hh"
#include "corecel/Types.hh"
#include "corecel/cont/Array.hh"
#include "corecel/data/Collection.hh"
#include "corecel/data/CollectionBuilder.hh"
#include "corecel/sys/ThreadId.hh"
Expand Down Expand Up @@ -72,6 +73,9 @@ struct VecgeomStateData
// Collections
Items<Real3> pos;
Items<Real3> dir;
#if CELERITAS_VECGEOM_SURFACE
Items<long> next_surface;
#endif

// Wrapper for NavStatePool, vector, or void*
detail::VecgeomNavCollection<W, M> vgstate;
Expand All @@ -82,8 +86,11 @@ struct VecgeomStateData
//! True if sizes are consistent and states are assigned
explicit CELER_FUNCTION operator bool() const
{
return this->size() > 0 && dir.size() == this->size() && vgstate
&& vgnext;
return this->size() > 0 && dir.size() == this->size()
#if CELERITAS_VECGEOM_SURFACE
&& next_surface.size() == this->size()
#endif
&& vgstate && vgnext;
}

//! State size
Expand All @@ -99,6 +106,9 @@ struct VecgeomStateData
CELER_EXPECT(other);
pos = other.pos;
dir = other.dir;
#if CELERITAS_VECGEOM_SURFACE
next_surface = other.next_surface;
#endif
vgstate = other.vgstate;
vgnext = other.vgnext;
return *this;
Expand All @@ -120,6 +130,9 @@ void resize(VecgeomStateData<Ownership::value, M>* data,

resize(&data->pos, size);
resize(&data->dir, size);
#if CELERITAS_VECGEOM_SURFACE
resize(&data->next_surface, size);
#endif
data->vgstate.resize(params.max_depth, size);
data->vgnext.resize(params.max_depth, size);

Expand Down
27 changes: 18 additions & 9 deletions src/geocel/vg/VecgeomParams.cc
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,12 @@
#include <cstddef>
#include <vector>
#include <VecGeom/base/Config.h>
#
#ifndef VECGEOM_VERSION
# include <VecGeom/base/Version.h>
#endif
#include <VecGeom/base/Cuda.h>
#include <VecGeom/base/Version.h>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've verified that this header (and the VECGEOM_VERSION macro therein) are present in v1.2.4, which is the minimum vecgeom required by Celeritas.

#include <VecGeom/management/ABBoxManager.h>
#include <VecGeom/management/BVHManager.h>
#include <VecGeom/management/GeoManager.h>
Expand All @@ -20,7 +25,7 @@
#ifdef VECGEOM_ENABLE_CUDA
# include <VecGeom/management/CudaManager.h>
#endif
#ifdef VECGEOM_USE_SURF
#if CELERITAS_VECGEOM_SURFACE
# include <VecGeom/surfaces/BrepHelper.h>
#endif
#ifdef VECGEOM_GDML
Expand Down Expand Up @@ -69,7 +74,7 @@ namespace
# define VG_CUDA_CALL(CODE) CELER_UNREACHABLE
#endif

#ifdef VECGEOM_USE_SURF
#if CELERITAS_VECGEOM_SURFACE
# define VG_SURF_CALL(CODE) CODE
#else
# define VG_SURF_CALL(CODE) \
Expand Down Expand Up @@ -106,11 +111,7 @@ int vecgeom_verbosity()
*/
bool VecgeomParams::use_surface_tracking()
{
#ifdef VECGEOM_USE_SURF
return true;
#else
return false;
#endif
return CELERITAS_VECGEOM_SURFACE;
}

//---------------------------------------------------------------------------//
Expand Down Expand Up @@ -381,7 +382,11 @@ void VecgeomParams::build_volume_tracking()

{
ScopedTimeAndRedirect time_and_output_("vecgeom::ABBoxManager");
#if VECGEOM_VERSION < 0x020000
vecgeom::ABBoxManager::Instance().InitABBoxesForCompleteGeometry();
#else
vecgeom::ABBoxManager_t::Instance().InitABBoxesForCompleteGeometry();
#endif
}

// Init the bounding volume hierarchy structure
Expand Down Expand Up @@ -613,9 +618,13 @@ void VecgeomParams::build_metadata()
VPlacedVolume const* pv = GeoManager::Instance().GetWorld();

// Calculate bounding box
#if VECGEOM_VERSION < 0x020000
auto bbox_mgr = ABBoxManager::Instance();
#else
auto bbox_mgr = ABBoxManager_t::Instance();
#endif
Vector3D<real_type> lower, upper;
ABBoxManager::Instance().ComputeABBox(pv, &lower, &upper);

bbox_mgr.ComputeABBox(pv, &lower, &upper);
return BBox{detail::to_array(lower), detail::to_array(upper)};
}();
}
Expand Down
Loading
Loading